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献 词 


献 给 Marcy、Annie 和 Molly， 愿 他 们 知道 我 是 做 什么 的 ， 以 及 为 何 而 
做 。 


瑞 国 著名 科学 家 具 具 教授 友 明 了 一 个 机 器 ， 不 用 打开 糖果 包装 ， 它 就 能 
立刻 告诉 你 里 面 有 没有 金 券 。 机 器 的 机 械 手 臂 出 手 如 电 ， 一 抓 一 个 准 
儿 ， 不 会 漏 挥 哪怕 藏 有 一 点 点 金子 的 任何 东西 。 目 前 看 来 ， 它 解决 了 所 
有 的 问题 。 











罗 尔 德 :达尔 ，《 查 理 和 巧克力 工厂 》 


一 人 一 人 
是 二 


近 半 数 的 美国 人 都 拥有 智能 手机 。 智 能 手机 也 是 计算 机 ， 其 计算 能 力 比 
儿 十 年 前 的 超级 计算 机 还 要 强 。 计 算 机 将 世界 上 的 信息 呈现 在 我 们 眼 

前 ， 也 帮 我 们 梳理 信息 。 计 算 机 让 和 人们 可 以 彼此 交流 ， 无 论 什么 映 份 ， 

地 处 何方 。 计 算 机 能 执行 数量 巨大 的 运算 ， 从 模拟 宇宙 事件 到 调度 复杂 
的 航线 。 计 算 机 可 以 识别 人 的 声音 、 面 孔 和 动作 。 计 算 机 可 以 获悉 人 们 
的 喜好 ， 并 据 此 推荐 图 书 、 音 乐 和 电影 。 在 不 远 的 将 来 ， 借 助 计算 机 技 
术 ， 无 人 驾驶 的 汽车 将 随处 可 见 。 这 么 说 ， 计 算 机 简直 无 所 不 能 。 


真是 这 样 吗 ? 在 这 本 书 里 ， 我 们 将 探讨 许多 计算 问题 ， 其 中 一 部 分 可 能 
永远 都 无 法 用 简单 的 计算 得 到 答案 。 试 着 解答 它们 是 计算 机 科学 ， 乃 至 
整个 数学 和 科学 领域 最 重要 的 挑战 。 人 们 给 这 些 问题 起 了 一 个 有 些 奇 怪 
的 名 字 : P/NP 问 题 。 


P/NP 是 克 雷 数学 研究 所 公布 的 7 个 干 祠 年 数学 难题 之 一 ， 该 研究 所 为 求 
解 这 道 难 题 设 立 了 百 万 美元 的 奖金 。 不 过 ，P/NP 问 题 的 意义 远 不 止 于 
此 。 


P 指 的 是 用 计算 机 能 很 快 求解 的 问题 ，NP 指 的 是 我 们 想 找到 最 优 解 的 问 
题 。 如 末 P=NP， 那 么 我 们 将 很 容易 找到 任意 给 定 问题 的 解 。P=NP 意 味 
独 我 们 所 了 解 的 社会 将 发 生 巨变 ， 医 学 、 和 科学、 娱乐 和 人 类 社会 一 切 任 
务 的 目 动 化 程度 都 将 立即 发 生 质 的 飞跃 。 


相反 ， 如 果 PzNP， 那 么 总 会 有 部 分 问题 无 法 迅速 地 被 解决 。 那 也 没有 
关系 ， 因 为 我 们 可 以 根据 具体 情况 研发 出 茶 些 技术 来 解决 这 些 问 题 。 
PzNP 意 味 着 不 可 能 用 上 自动 化 的 方法 解决 所 有 问题 。 然 而 ， 知 道 哪 些 工 
具 不 好 用 也 有 助 于 人 们 找到 更 好 用 的 工具 。 


2008 年 8 月 ，《ACM 通 讯 》 的 主编 英 舍 : 瓦 迪 约 我 写 一 篇 天 于 P/NP 问 题 
的 文章 。ACM (美国 计算 机 协会 ) 是 一 个 为 计算 机 研究 学 者 和 从 业 人 
员 服 务 的 重要 社团 ，《ACM 通 讯 》 则 是 该 协会 刊登 文章 的 主要 杂志 。 


一 开始 我 想 把 写 稿 的 事 推 给 另 一 位 计算 机 科学 家 ， 但 后 来 我 还 是 答应 
了 了。 当时 更 舍 是 这 么 劝说 我 的 : “如 果 那 帮 有 物理 学 家 可 以 写 天 于 弦 理 论 
的 畅销 文革 (和 图 书 ) ， 那 我 们 也 可 以 癌 公 众 解释 计算 复杂 上 度 理论 目前 























的 进展 ， 我 希望 如 此 。” 于 是 我 写 了 一 篇 文章 ， 该 文章 以 《ACM 通 讯 》 
的 读者 为 主要 受众 ， 不 仅 介 绍 了 P/NP 问 题 的 现状 〈 基 本 可 以 概括 为 * 悬 
而 未 诀 >) ， 也 讲 了 一 些 人 们 在 处 理 困难 问题 时 积累 的 技巧 。“P/NP 问 题 
的 现状 ”(The Status of the P versus NP Problem ) 发 表 在 2009 年 9 月 的 
《ACM 通 讯 》 上 ， 它 很 快 就 成 为 该 刊物 创刊 以 来 下 载 次 数 最 多 的 文 
章 。 


关于 P/NP 问 题 ， 我 觉得 还 有 很 多 故事 可 讲 ， 而 那 篇 文章 的 大 受 欢 迎 ， 似 
乎 表明 是 时 候 面 向 更 广 的 受众 (而 不 仅 是 科学 家 们 ) 来 讲述 这 些 故 事 
Ve 











我 将 那 篇 短文 作为 本 书 的 框架 结构 ， 将 原来 文章 的 各 个 部 分 扩展 为 现在 
的 章节 。 我 还 受到 了 史蒂芬 -霍金 的 《时 间 简 史 》 的 启发 :， 该 书 尽量 绕 
开 了 星 梁 的 公式 和 术语 ， 采 用 生动 的 例子 和 故事 来 解释 物理 。 我 试图 以 同 
样 的 方式 来 讲解 PNP 问题 ， 借 此 探讨 P/NP 问 题 的 本 质 和 重要 意义 。 

本 书 没 有 给 出 PNP 问题 的 正式 定义 ， 有 很 多 教科 书 和 网 站 都 详细 论述 了 
P 和 NP 的 定义 及 技术 结论 。 本 书 则 在 让 你 对 计算 科学 的 潜能 和 局 限 性 有 
更 多 的 了 解 ， 这 非常 有 好 处 ， 毕 竟 计 算 机 如 今 已 成 为 人 类 生活 不 可 或 缺 
的 部 分 了 。 


向 P 和 NP 进 发 吧 ! 
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于 伊利 诡 伊 州 埃 文 斯 顿 


致谢 


首先 感谢 Moshe Vardi， 是 他 鼓励 我 写作 ， 他 也 是 我 发 表 在 《ACM 通 
讯 》 杂 志 上 的 “P/NP 问 题 的 现状 ”一 文 的 编辑 。 这 篇 文章 受 欢迎 的 程度 让 
我 萌发 了 把 它 扩 展 成 一 本 科普 书 的 念头 。 


跟 我 一 块 写 博客 的 Bill Gasarch 不 断 辟 励 我 ， 并 仔细 审阅 了 全 书 各 章 的 初 
稿 。Alana Lidawer 和 John、Jim， 以 及 Chris Purtilo 也 阅读 了 全 书 的 初 

稿 ， 并 提出 了 许多 宝贵 意见 。KuanLing Chen、Josh Grochow、Ralph 
Hansen、Adam Kalinich、David Pennock 和 Rahul Santhanam 分 别 对 本 书 
的 部 分 章节 提出 了 许多 宝贵 的 意见 。 








Manuel Blum、 Steve Cook、 David Johnson、Leonid Levin 和 Albert Meyer 
分 别 以 其 个 人 独到 的 视角 癌 我 讲述 了 P/NP 问 题 的 早期 历史 。Alexander 
Razborov 对 俄罗斯 历史 的 介绍 对 我 帮助 很 大 。 


这 本 书 的 写作 离 不 开 我 的 生活 圈子 。 作 为 计算 机 科学 家 ， 我 在 工作 和 生 
活 中 会 与 其 他 研究 人 员 、 学 生 ， 以 及 数 不 清 的 人 交流 ， 这 种 交流 也 让 我 
受益 有 菲 浅 。 在 此 特别 感谢 加 州 大 学 伯克利 分 校 、 麻 省 理工 学 院 、 迄 加 哥 
大 学 、 阿 姆 斯 特 丹 的 数学 与 计算 机 科学 中 心 、NEC 研 究 院 、 丰 田 工业 大 
学 芝加哥 分 校 以 及 西北 大 学 的 同行 们 ， 与 他 们 真挚 而 友好 的 讨论 让 我 获 
葵 民 多 。 


男 外 ， 我 还 要 特别 感谢 两 个 人 ， 他 们 对 我 早年 P/NP 问 题 观 念 的 形成 影响 
很 大 : Juris Hartmanis， 我 在 康 奈 尔 大 学 读本 科 期 间 首 次 从 他 这 里 接触 
到 了 P 和 NP， 还 有 Michael Sipser， 他 是 我 在 加 州 大 学 伯克利 分 校 和 有 奢 省 
理工 学 院 的 博士 学 位 指导 老师 和 好 朋友 。 


在 为 第 6 章 的 地 图 填 色 问题 寻找 例子 时 ， 我 在 网 上 寻求 了 帮助 ， 感 谢 那 
些 做 出 回应 的 人 : Chris Bogart、HsienChih Chang、Pélvolgyi Domotor、 
David Eppstein、Lukasz Grabowski、Gil Kalai、Charles Martel 以 及 
Derrick Stolee。 


写作 期 间 ， 我 在 西北 大 学 的 Robert R. McCormick 工 程 与 应 用 科学 学 院 担 
任 电 子 工程 和 计算 机 科学 教授 。 西 北大 学 十 分 鼓励 癌 公 众 传播 知识 的 浇 
书 活 动 。 我 充分 利用 了 教 职 的 特权 ， 尤 其 是 利用 了 学 校 图 书馆 丰富 的 资 


源 ， 包 括 纸 质 文 献 和 电子 文献 。 西 北大 学 的 教 职 工 是 最 棒 的 ， 我 的 行政 
助理 Marjorie Reyes 对 我 帮助 同样 很 大 。 


普林斯顿 大 学 出 版 社 的 编辑 Vickie Kearn 为 我 提供 了 悉心 的 指导 ， 并 在 
著 书 的 各 个 阶段 仔细 审阅 了 手稿 ， 让 这 本 书 变 得 更 好 。 我 还 想 感 谢 
Vickie 的 助手 Quinn Fusting， 以 及 出 版 社 的 全 体 工 作 人 员 。 


最 大 的 感谢 留 给 我 的 家 人 : 妻子 Marcy、 两 个 女儿 Annie 和 Molly， 感 谢 
她 们 对 我 的 爱 与 救 励 。 


第 1 革 金 券 


一 个 糖果 三 老板 决定 推出 一 个 活动 ， 将 五 张 金 券 藏 到 巧 元 力 的 包 闭 里 ， 
而 这 种 巧克力 每 年 的 产量 数 以 干 万 计 。 找 到 金 券 的 人 将 得 到 一 次 珍贵 的 
参观 工厂 的 机 会 。 


如 何 找到 这 些 金 券 ? 你 可 以 买 尽 可 能 多 的 巧 殉 力 。 你 可 能 会 试 试用 磁 

铁 ， 可 惜 金 没 有 磁性 。 或 者 你 可 以 雇用 数 千 人 ， 让 他 们 每 人 得 得 一 小 堆 
巧克力 。 这 听 起 来 很 途 ， 但 是 小 姑娘 维 露 卡 ' 索 尔 特 就 要 这 么 做 ， 因 为 
她 特别 想得到 一 张 金 券 ， 去 参观 威 利 ' 旺 卡 的 巧 元 力 工厂 。 


维 露 卡 的 父亲 索 尔 特 先 生 是 个 富商 ， 他 决定 买 光 他 能 找到 的 巧克力 。 这 
还 不 够 ， 惑 算 有 堆积 如 山 的 巧 苑 力 ， 要 从 中 找到 小 小 的 金 券 也 很 困难 。 
索 尔 特 先生 也 有 一 家 工厂 ， 他 不 异动 用 工厂 的 工人 ， 终 于 找到 了 一 张 金 
券 。 他 对 记者 讲述 了 找到 金 券 的 过 程 : 


我 是 做 花生 生意 的 ， 知 道 吧 ， 我 有 大 约 100 个 女工 为 我 剥 花生 ， 然 后 
将 它们 做 成 烧 花 生 米 和 腌 花生 米 。 她 们 整 天 就 坐 在 那儿 剥 花 生 。 所 以 
我 跟 她 们 说 :“ 好 了 姑娘 们 ， 不 要 和 剥 从 生 了 ， 大 家 开始 给 我 刊 这 些 破 
糖 纸 吧 ! ”然后 她 们 就 剥 。 我 让 工厂 的 每 一 个 工人 都 饥 足 了 劲 地 撕 掉 
巧 殉 力 的 包装 纸 ， 从 早 干 到 上 晚 。 


但 是 三 天 过 去 了 ， 我 们 还 是 没 走运 。 哦 ， 那 可 真 够 哈 ! 我 可 怜 的 小 维 
露 卡 越 来 越 暴 躁 ， 每 次 我 一 回 家 她 就 朝 我 喷 嘎 : “我 的 金 券 在 哪儿 ? 
我 要 我 的 金 券 ! ?她 撒 泌 又 打滚 儿 ， 踢 腿 又 叫喊 ， 实 在 招 人 烦 。 我 可 
不 希望 看 到 我 的 小 宝贝 这 么 不 高 兴 ， 所 以 我 决定 一 直 找 ， 不 找到 她 要 
的 东西 署 不 村 休 。 终 于 ， 在 第 四 天 的 晚上 ， 一 个 女工 大 叫 : “我 找到 
金 券 了 ! ”然后 我 说 :“ 把 它 给 我 ， 快 ! ”她 给 了 我 ， 然 后 我 跑 着 回 家 
把 它 交 给 了 亲爱 的 维 露 卡 ， 她 高 兴 得 合 不 扰 嘴 。 我 们 家 又 变 得 其 乐 融 
融 了 。 
和 索 尔 特 先 生 一 样 ， 无 论 你 打算 怎么 找 那 张 金 券 ， 你 都 需要 大 量 时 间 、 
金钱 ， 或 者 运气 。 也 许 有 一 天 ， 有 人 能 发 明 出 一 个 快速 找到 金 券 的 便宜 
装置 ， 也 许 这 样 的 装置 并 不 存在 。 


然而 ，1000 万 对 于 今天 的 计算 机 来 说 只 是 很 小 的 数字 。 如 果 你 把 糖果 数 




















字 化 ， 录 入 一 个 数据 库 ， 现 在 的 电脑 只 用 不 到 一 秒 就 能 把 它 找 一 过 。 虽 
然 计算 机 比 人 快 得 多 ， 但 它 面 对 的 问题 的 规模 也 比 在 糖果 里 找 金 券 大 得 
多 。 


现在 最 大 的 电子 数据 集合 规模 有 多 大 ? 比如， 整个 互联 网 ， 考 虑 到 所 有 
视频 、 音 频 、 电 子 邮 件 及 其 他 一 切 ， 总 的 信息 量 差 不 多 有 1 000 000 000 
000 000 000 字 节 ， 最 多 相差 几 个 0。 一 个 字 节 大 致 对 应 键盘 上 的 一 个 字 
符 。 这 个 数 很 大 ， 但 记 住 ， 计 算 机 也 很 快 。 一 般 的 笔记 本 电脑 每 秒 可 以 
执行 1 万 亿 次 操作 ， 这 样 算 来 ， 理 论 上 只 需要 不 到 4 个 月 就 能 搜 完整 个 互 
联网 的 内 容 ， 前 提 是 你 能 把 整个 互联 网 装 到 你 电脑 的 内 存 里 。Google 每 
时 每 刻 都 在 搜索 整个 互联 网 ， 它 使 用 了 几 十 万 台 快 速 的 计算 机 。 


如 果 计 算 机 可 以 很 快 地 搜 志 整个 互联 网 ， 看 起 来 好 像 我们 就 解决 了 这 个 
找 金 券 问 题 的 电子 版 。 但 是 ， 计 算 机 不 仅 要 帮 人 们 搜索 已 有 的 数据 ， 还 
要 搜索 问题 的 所 有 可 能 解 。 


认识 一 下 可 怜 的 旅行 推销 员 Mary， 她 来 目 华 盛 顿 特 区 ， 为 美国 木 析 集团 
公司 工作 。 她 需要 从 家 乡 旅行 到 48 个 州 的 首府 ， 回 各 州 法 院 推 销 木 析 。 
木 杞 公司 为 了 削减 成 本 ， 让 Mary 找 到 通过 所 有 城市 的 最 短路 径 。Mary 
画 了 一 张 鲜 ， 写 与 男 画 了 一 会 儿 ， 制 订 了 一 个 不 错 的 路 线 。 























总 距离 =11 126 英 里 


图 1-1 旅行 推销 员 问 题 的 地 图 


1 1 英里 约 合 1.609 千 米 。 编者 注 




















差 旅 部 门 的 人 想 让 Mary 试 试 能 否 找到 另 一 条 路 线 ， 把 路 程 缩短 到 11 000 
英里 以 下 。Mary 写 了 个 计算 机 程序 ， 试 图 穷 举 所 有 可 能 的 路 线 ， 找 出 最 
短 的 一 条 ， 但 是 一 周 以 后 ， 程 序 还 没 跑 完 。Mary 坐 下 来 开始 算数 。 作 为 
第 一 站 的 城市 有 48 种 选择 ， 然 后 从 剩 下 的 47 个 城市 中 选 一 个 作为 第 二 
站 ， 再 从 剩 下 的 46 个 城市 中 选 一 个 ， 以 此 类 推 。 可 能 的 路 径 共 
48x47x46x...x2x1 种 ， 也 就 是 下 面 这 个 62 位 数 : 


12 413 915 592 536 072 670 862 289 047 373 375 038 521 486 354 677 760 
000 000 000 


即使 计算 机 计算 一 条 路 线 的 时 间 等 于 光 通 过 最 小 的 原子 直径 的 时 间 〈 大 
约 0.000 000 000 000 000 000 33 秒 ) ， 仍 然 需要 十 亿 亿 亿 倍 于 宇宙 年 龄 

的 时 间 才 能 算 完 。 难 怪 Mary 的 电脑 算 了 一 周 还 没有 完 。Mary 想 知道 有 

没有 比 穷 举 更 好 的 方法 找到 最 佳 路 线 ， 就 像 在 所 有 可 能 行程 的 “巧克力 

山里 面 刨 出 那 张 小 小 的 金 券 。 


这 就 是 本 书 最 基本 的 问题 : INP 问 题 。 其 中 的 一 个 实例 就 是 能 否 为 旅行 
推销 员 找 到 最 短路 径 。P 和 NP 目 有 其 十 分 专业 的 定义 ， 但 是 把 它们 看 做 
概念 比 看 做 数学 对 象 更 好 。NP 是 存在 解 的 问题 的 集合 ，P 则 是 能 很 快 找 
到 解 的 问题 的 集合 。P=NP 意 味 着 我 们 能 总 是 很 快 地 计算 出 任何 问题 的 
解 ， 当 然 也 包括 找到 旅行 推销 员 的 最 短路 径 。 相 反 ，PzNP 意 味 痢 我 们 
不 能 。 























1.1 划分 的 难题 
看 下 边 38 个 数字 : 


14 175, 15 055, 16 616, 17 495, 18 072, 19 390, 19 731, 22 161, 23 320, 23 
717, 26 343, 28 725, 29 127, 32 257, 40 020, 41 867, 43 155, 46 298, 56 734, 
57 176, 58 306, 61 848, 65 825, 66 042, 68 634, 69 189, 72 936, 74 287, 74 
537, 81 942, 82 027, 82 623, 82 802, 82 988, 90 467, 97 042, 97 507, 99 564 


这 38 个 数字 之 和 为 2000 000。 你 能 把 它们 平分 成 两 组 ， 每 组 19 个 数字 之 
和 分 别 为 1000 000 吗 ?你 可 以 使 用 计算 器 、 电 子 表格 或 写 一 个 计算 机 程 
序 。 (答案 在 本 章 最 后 。) 


不 那么 简单 ， 是 吧 ? 把 这 些 数 分 成 两 组 有 170 亿 种 方式 。 如 果 程 序 编 得 
巧妙 ， 使 用 当今 较 快 的 计算 机 能 够 找到 一 个 解 。 但 如 果 给 你 3800 个 数 ， 
或 者 3800 万 个 数 呢 ? 短 小 的 计算 机 程序 可 没 法 给 出 答案 了 ! 


这 只 是 个 无 意义 的 数学 谈 题 吗 ? 就 算 存 在 一 个 厉害 的 计算 机 程序 ， 它 能 
解决 这 个 平分 数组 的 问题 〈 假 设 有 解 ) ， 那 又 如 何 呢 ? 如果 是 这 样 的 
话 ， 我 们 能 用 这 个 程序 做 更 多 的 事 。 这 个 程序 能 解决 所 有 的 问题 ， 包 括 
旅行 推销 员 问 题 。 这 个 简短 的 难题 抓 住 了 P/NP 问 题 的 本 质 ， 一 个 程序 如 
果 能 解决 这 个 难题 的 复杂 版 本 ， 那 么 它 也 能 解 出 任意 问题 。 


1.2 手 


你 的 手 是 最 不 可 思议 的 工程 装置 ， 它 能 戳 、 抓 和 指 ， 能 系 鞋 珊 ， 能 射 

箭 ， 还 能 弹 钢 蕉 、 拉 小 提 蕉 ， 能 变 戏法 ， 能 驾驶 车 、 船 、 火 车 或 飞机 。 
你 的 手 可 以 握 住 其 他 人 的 手 ， 或 跟 他 们 玩 拇 指 相 扑 。 手 可 以 比划 出 信和 号 
语言 ， 也 能 通过 写字 或 打字 来 交流 。 手 可 以 轻 抚 ， 也 能 重 击 。 手 可 以 使 
用 修理 钟表 的 精密 工具 ， 也 能 操作 和 链条 锯 。 有 才华 的 人 的 双手 可 以 创造 
艺术 杰作 ， 写 出 音乐 或 诗歌 。 人 类 取得 的 几乎 所 有 成 就 ， 都 离 不 开 双 
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一 只 手 有 27 块 骨头 ，5 根 手指 ， 包 括 最 重要 的 拇指 。 手 具有 结构 复杂 的 
神经 、 肌 腿 和 肌肉 ， 这 些 都 包 庄 在 富有 弹性 的 皮肤 里 。 然 而 ， 这 一 不 可 
思议 的 装置 ， 自 然 造物 的 杰作 ， 却 不 能 自己 做 事 ， 而 只 能 执行 人 脑 的 指 
令 。 死 人 的 手 平平 无 奇 ， 做 不 了 任何 事情 。 


手 就 是 自然 的 硬件 ， 硬 件 本 喘 不 能 做 什么 。 手 需要 软件 (也 就 是 大 脑 指 
令 ) 来 控制 ， 软 件 告 诉 它 如 何 执 行 和 实现 大 脑 希 望 它 做 的 事情 。 


松 内容 子 是 华 右 顿 大 学 的 机 器 人 学 教授 ， 她 高 领 科研 小 组 制作 了 一 个 解 
误 学 上 正确 无 误 的 机 械 手 ， 其 手指 有 和 人 类 手指 同样 的 动作 自由 度 。 理 
论 上 她 的 机 械 手 可 以 完成 人 手 能 做 的 任何 事情 ， 但 实际 上 ， 它 只 能 完成 
很 简单 的 任务 ， 因 为 写 一 个 计算 机 程序 来 全 方位 控制 松 四 的 机 械 手 ， 是 
非常 困难 的 。 在 协调 多 块 肌肉 的 运动 时 ， 即 使 是 完成 最 简单 的 任务 ， 也 
需要 很 复 洒 的 代码 。 


然而 我 们 的 脑残 能 控制 手 。 可 以 将 脑 看 做 一 个 性 能 强大 的 计算 机 ， 如 果 
脑 能 控制 手 去 系 鞋 带 或 是 创作 艺术 ， 那 么 计算 机 程序 也 一 定 能 。 


知道 这 样 的 程序 存在 并 不 意味 着 残 能 找到 它们 。 随 奢 时 间 的 推移 ， 计 算 
机 科学 家 肯定 会 写 出 更 精深 的 程序 ， 松 内 的 机 械 手 将 能 执行 更 复 茶 的 活 
动 。 这 肯定 是 一 个 精彩 的 旅程 ， 但 也 可 能 进展 缓慢 、 举 步 维 艰 。 


一 定 要 这 样 缓慢 吗 ? 想象 一 下 ， 只 要 我 们 简单 描述 一 项 任务 ， 马 上 就 会 
有 一 个 程序 提供 相应 的 功能 ， 给 计算 机 输入 一 段 演示 人 如 何 打 结 的 电 
影 ， 然 后 它 并 刻 束 能 用 机 械 手 重 复 打 结 的 过 程 ， 把 莎士比亚 全 集 录入 计 


























算 机 ， 然 后 它 就 能 创作 一 部 新 的 “莎士比亚 ”戏剧 ; 只 要 我 们 能 认 出 某 个 
东西 ， 就 能 找到 它 。 这 些 梦 想 都 能 成 真一 一 前 提 是 P=NP。 


P/NP 问 题 的 魅力 就 在 这 里 。 究 竟 能 人 否 让 所 有 的 事 都 变 得 易如反掌 ? 还 是 
说 ， 有 些 事情 注定 就 没有 简单 的 解决 方法 ? 不 能 排除 这 种 可 能 性 。 无 论 
如 何 ， 我 们 并 不 指望 生活 会 那么 简单 。 尽 管 我 们 并 不 认为 P=NP， 但 这 
么 美好 的 世界 却 让 我 们 妨 不 住 充满 懂 慢 。 











1.3 ”P/NP 问 题 


P/NP 问 题 讨论 的 是 以 上 所 述 的 所 有 问题 ， 以 及 许多 与 之 类 似 的 问题 。 它 
们 归根 到 底 都 是 在 问 : 我 们 搜索 大 量 可 能 性 的 速度 能 有 多 快 ? 我 们 找 
到 “人 金 券 ”〈 即 最 佳 答案 ) 的 过 程 能 变 得 多 容易 ? 


P/NP 问 题 是 库 尔 特 : 哥 德尔 在 1956 年 寄 给 约翰 : 冯 : 诺 依 曼 的 一 封 信 中 首次 
提出 的 ， 哥 德尔 和 冯 : 诺 依 曼 都 是 20 世 纪 数 学 界 的 泰斗 。 这 封 信 后 来 不 
幸 遗 失 ，20 世 纪 80 年 代 又 被 找到 。P/NP 问 题 在 学 术 界 的 亮相 是 在 20 世 纪 
70 年 代 初 ， 由 斯 蒂 芬 . 库 区 和 列 昂 尼 德 . 莱 文 独立 提出 ， 当 时 两 位 所 在 的 
国家 正在 冷战 。 之 后 理 查 德 : 卡 普 列 出 了 这 个 领域 中 的 21 个 重要 难题 ， 
包括 前 面 提 到 的 旅行 推销 员 难 题 和 划分 难题 。 计 算 机 科学 家 从 卡 普 的 工 
作 开 始 认识 到 P/NP 问 题 极为 重要 ， 由 此 计算 机 科学 研究 的 方向 发 生 了 戏 
剧 性 的 转变 。 如 今 ，P/NP 问 题 的 关键 性 作用 已 经 不 仅 限于 计算 机 科学 领 
域 ， 还 延伸 到 其 他 许多 领域 ， 如 生物 学 、 医 学 、 经 济 学 和 物理 学 。 


P/NP 问 题 已 成 为 所 有 数学 领域 最 难 的 开放 问题 之 一 。1994 年 安德鲁 - 怀 
尔 斯 证 明了 费 马 大 定理 ， 受 这 一 消息 的 茎 舞 ， 克 和 雷 数学 研究 所 决定 举办 
竞赛 ， 攻 区 他 们 认为 最 为 重要 而 尚未 解决 的 数学 难题 。2000 年 ， 他 们 列 
出 了 下 面 这 7 个 千 和 禧 年 难题 ， 并 为 每 道 难 题 的 攻破 设立 了 100 万 美元 的 奖 
人 


Eo 





. 贝 赤 和 斯 维 讷 通 - 戴 尔 猜 想 (Birch and Swinnerton-Dyer conjecture) 
. 霍 奇 猜想 〈Hodge conjecture) 

. 纳 维 -斯 托 克 斯 方程 (Navier-Stokes equations ) 

. P/NP 问 题 (P versus NP) 

. 庞 加 莱 猿 想 (Poincaré conjecture) 

. 歼 曼 猿 想 (Riemann hypothesis ) 

. 杨 -米尔 斯 理论 (Yang-Mills theory) 


干 禧 年 难题 中 的 庞 加 莱 猜 想 已 于 2003 年 被 格 里 高 利 : 佩 雷 尔 曼 解决 ， 但 
他 拒绝 了 100 万 美元 的 奖金 。 截 至 本 书写 作 时 其 他 6 个 难题 者 尚未 解决 。 


解决 P/NP 问 题 就 能 拿 到 100 万 美元 ， 这 可 是 货真价实 的 金 券 啊 ! 


TJHOUURWUDO~ 








更 妙 的 是 ， 如 果 你 能 证 明 P=NP， 那 么 你 也 就 掌握 了 找到 金 券 的 秘诀 ， 

解决 其 余 的 干 祠 年 难题 将 是 举 手 之 劳 。 也 就 是 说 ， 证 明了 P=NP， 你 就 
能 解决 6 道 千 禧 年 难题 ， 并 得 到 600 万 美元 。 然 而 证 明 P=NP 或 PzZNP 可 没 
那么 容易 。 一 心 想得到 600 万 美元 的 人 最 好 去 玩 彩票 ， 那 样 把 握 更 大 一 


些 。 





1.4 ”找到 金 券 


有 了 时候 我 们 能 够 找到 人 金 券 。 比 如 我 在 芝加哥 ， 想 开车 去 纽约 ， 往 车 载 

GPS 里 输入 地 址 ， 一 两 分 钟 之 内 它 就 能 给 出 一 条 从 芝加哥 到 纽约 的 最 快 
路 线 ， 然 后 我 就 可 以 踏 上 旅程 了 。 几 百 万 字 节 的 内 存 便 可 容纳 全 部 的 美 
国 街道 地 图 ， 但 地 图 中 可 能 的 路 线 远 远 超过 几 百 万 。 从 芝加哥 到 纽约 所 
有 可 能 的 行车 路 线 有 多 少 条 ? 不 开 错 方 加 的 情况 下 ， 保 守 计 算 可 得 出 的 
路 线 数目 大 到 了 “不 可 思议 ”， 即 1 后 边 跟 63 个 0。GPS 根 本 没有 时 间 检 查 
所 有 的 可 能 性 ， 但 还 是 能 找到 最 快 的 路 线 。 


旅行 时 间 有 一 个 有 趣 的 性 质 。 随 便 选 一 个 中 间 地 点 《比如 匹兹堡 ) ， 从 
芝加哥 经 过 匹 效 代 到 纽约 的 最 短路 线 ， 一 定 是 芝加哥 到 匹 效 堡 的 最 短路 
线 ， 再 接 上 匹 效 您 到 纽约 的 最 短路 线 。 不 走 匹 效 堡 可 能 有 更 快 的 路 线 ， 
但 是 芝加哥 到 纽约 的 最 短路 线 ， 绝 不 会 比 从 芝加哥 经 过 匹 效 代 到 纽约 的 
最 短路 线 还 要 长 。 


GPS 的 计算 机 程序 正 古 利用 了 这 个 性 质 ， 快 速 缩小 搜索 范围 并 找到 了 最 
佳 路 线 。 这 可 能 仍 需 要 检查 上 亿 条 路 线 ， 但 是 GPS 的 计算 机 处 理 紫 完全 
能 胜任 ， 毕 葛 这 个 数字 比 “ 不 可 思议 ?小 多 了 。 


找到 最 短路 径 并 没有 体现 PINP 问 题 的 全 部 力量 。 最 短路 径 问 题 告 诉 我 
们 ， 全 部 的 可 能 性 数量 特别 大 ， 但 这 并 不 总 意味 着 必须 过 历 所 有 的 可 能 
性 才能 找到 答案 。P/NP 问 题 其 实 是 问 ， 是 不 是 对 于 任意 给 定 的 搜索 问 
题 ， 我 们 都 不 必 这 历 所 有 的 可 能 性 台 能 找到 答案 ? 
































1.5 漫漫 长 途 


本 书 讲 的 是 P 和 NP 的 故事 。 什 么 是 P 和 NP? P/NP 描 述 的 是 哪 类 问题 ? 所 
有 搜索 问题 中 最 难 的 问题 一 “NP 完全 问题 * 是 怎么 回 事 ? 这 些 问 题 如 何 
影响 PINP 问 题 ? 


举 个 简单 的 例子 ，Facebook 上 的 好 友 圈 子 ( 即 团 ，clique〉 中 ， 最 大 的 
包含 多 少 人 ?100 人 ， 还 是 1000 人 ? 即使 你 拥有 Facebook 的 全 部 数据 ， 
这 个 问题 也 很 难 求解 。 求 解 较 大 规模 团 问题 的 困难 程度 ， 不 亚 于 任何 搜 


索 问 题 。 


如 果 P=NP 会 怎么 样 ? 那么 我 们 将 迎 来 一 个 美好 的 世界 ， 计 算 所 有 的 事 
物 都 将 易如反掌 。 我 们 能 快速 地 了 解 一 切 ， 揭 开 世 界 上 所 有 事物 的 神秘 
面纱 ， 从 治 鳄 绝症 到 洞悉 宇宙 的 本 质 。 美 好 的 世界 也 有 它 灰 瞳 的 一 面 ， 

“0 丢掉 工作 ， 因 为 没有 什么 是 计算 机 不 能 知道 或 完成 

ye 


这 样 美好 的 世界 几乎 不 太 可 能 。 困 难 的 搜索 问题 仍 将 存在 ， 我 们 想 要 其 
至 需要 找到 它们 的 答案 。 其 实 我 们 大 可 不 必 放 弃 。 计 算 机 科学 家 已 研发 
出 许多 技术 ， 包 括 很 有 可 能 对 许多 问题 奏效 的 启发 式 方法 ， 以 及 能 给 出 
接近 理想 解 的 近似 技术 。 


P 和 NP 问 题 是 如 何 产 生 的 ? 这 个 故事 发 生 在 世界 因 冷 战 被 割裂 的 那 段 日 
子 ， 其 实 可 以 把 它 分 成 两 个 故事 来 讲 。 有 关 高 性 能 计算 的 思路 和 问题 分 
别 在 两 个 世界 独立 发 展 ， 而 这 两 个 世界 的 研究 最 终 殊 途 同 归 ， 从 而 产生 
了 P/NP 问 题 。 


从 哪里 着 手 证 明 PzNP? 库 尔 特 :可 德尔 证 明 数 学 不 能 解决 所 有 的 问题 。 
能 人 否 用 类 似 的 方法 ， 证 明 存 在 不 能 快速 解决 的 搜索 问题 ? 为 了 分 析 问 题 
的 复杂 度 ， 我 们 可 以 把 计算 过 程 分 解 为 最 基本 的 单元 。 算 术 几 何 学 《〈 数 
学 的 一 个 抽象 分 文 ) ， 为 人 们 能 在 有 参 一 日 解决 这 个 重要 的 问题 带 来 了 
新 的 希望 。 但 我 们 距离 那 一 天 还 很 远 。 


PzxNP 会 带 来 什么 好 处 呢 ? 它 能 帮助 我 们 保守 秘密 ， 产 生 看 上 去 真 随机 
的 伪 随 机 数 。 




















未 来 基于 量子 力学 的 计算 机 能 否 让 P/NP 问 题 变 得 无 足 轻 重 ? 不 太 可 能 ， 
不 过 量子 计算 机 的 建成 将 解决 一 部 分 现在 计算 机 束 手 无 保 的 问题 ， 比 如 
大 数 的 因数 分 解 。 此 外 ， 量 子 力 学 也 会 透露 P 是 否 等 于 NP 的 玄机 。 


未 来 将 会 如 何 呢 ? 我 们 仍 将 面临 计算 领域 的 巨大 挑战 。 人 们 如 何 与 互相 
协作 处 理 问题 的 计算 机 打交道 ?如 何 分 析 每 天 产生 的 海量 数据 ? 所 有 事 
物 都 能 联网 ， 世 界 将 会 怎样 ? 要 解决 这 些 问 题 ，P/NP 问 题 只 会 变 得 更 为 
关键 。 





1.6 ”划分 难题 的 解 
以 下 38 个 数 


14 175, 15 055, 16 616, 17 495, 18 072, 19 390, 19 731, 22 161, 23 320, 23 
717, 26 343, 28 725, 29 127, 32 257, 40 020, 41 867, 43 155, 46 298, 56 734, 
57 176, 58 306, 61 848, 65 825, 66 042, 68 634, 69 189, 72 936, 74 287, 74 
537, 81 942, 82 027, 82 623, 82 802, 82 988, 90 467, 97 042, 97 507, 99 564 


可 分 成 如 下 两 组 : 


15 055, 16 616, 19 390, 22 161, 26 343, 40 020, 41 867, 43 155, 46 298,57 
176, 58 306, 65 825, 66 042, 69 189, 74 537, 81 942, 82 623, 82 988,90 467 


和 


14 175, 17 495, 18 072, 19 731, 23 320, 23 717, 28 725, 29 127, 32 257, 56 
734, 61 848, 68 634, 72 936, 74 287, 82 027, 82 802, 97 042, 97 507, 99 564 


每 组 中 所 有 数字 之 和 都 是 1 000 000。 


第 2 草 ”美妙 的 世界 


假设 有 人 请 你 写 一 篇 关于 过 去 20 年 互联 网 带 来 的 社会 变 章 的 论文 。 你 是 
写 闭 在 口袋 里 的 设备 让 人 们 能 够 随时 访问 所 有 公开 的 信息 ， 还 是 会 探讨 
发 生 在 音乐 、 电 影 、 出 版 和 新 闻 产 业 的 巨大 变化 ? 无 论 怎么 写 ， 短 短 一 
篇 论文 都 很 难 公允 地 描述 过 去 20 年 发 生 的 变化 。 好 了 ， 再 想象 一 下 : 如 
果 是 让 你 在 这 些 变化 尚未 发 生 的 20 世 纪 90 年 代 写 这 篇 论文 ， 你 又 会 对 未 
来 做 出 怎样 的 预测 ? 


如 果 P=NP 被 证 实 ， 即 我 们 掌握 了 一 种 对 所 有 NP 问题 都 有 效 的 快速 算 
法 ， 那 么 社会 将 发 生 更 加 巨大 的 变化 ， 互 联网 看 起 来 只 是 历史 的 一 个 补 
充 说 明 。 不 光 不 可 能 描述 全 部 的 变化 ， 甚 至 不 太 可 能 预测 新 技术 带 来 的 
深远 影 啊 。 


为 了 能 让 读者 对 那个 美妙 的 世界 有 些许 认 知 ， 现 在 让 我 们 来 想象 一 下 发 
现 解决 NP 问题 的 有 效 算法 儿 年 之 后 会 发 生 什 么 。 让 我 们 一 起 跳 到 2026 
年 ， 去 看 看 一 个 P=NP 被 证 实 的 世界 一 一 当然 ， 这 个 世界 是 科 约 的 。 首 
先 ， 明 们 来 看 看 这 个 世界 是 怎么 打造 出 来 的 。 











2.1 厄 巴 纳 算法 


2016 年 ， 捷 元 数学 家 米 羔 娜 -由 维尔 用 邮件 转发 了 一 个 她 认为 理论 上 能 
有 效 解决 NP 问题 的 算法 。 计 算 机 科学 和 数学 界 经 过 仔细 验证 ， 一 致 认 
为 米 有 羔 娜 所 言 不 虚 ， 算 法 确实 解决 了 伟大 的 P/NP 问 题 。 米 羔 娜 将 算法 发 
表 成 论文 ， 文章 本 里 的 名 字 很 低调 ， 叫 做 “ 论 一 个 库 克 没有 解决 的 问 
题 ”(COn an Open Problem of Cook) ， 而 《纽约 时 报 》 介 绍 文章 的 标题 
更 为 直 白 ， 恰 如 其 分 地 表明 了 它 的 价值 : “P=NP”。 


2018 年 ， 米 莱 娜 成 为 第 一 个 获得 数学 领域 最 高 薪 翟 〈 菲 尔 效 奖 ) 的 女 

性 。 一 年 后 殉 雷 数学 研究 所 炎 给 米 沫 娜 一 张 价值 100 万 美元 的 文 紧 。 她 
成 为 继 格 里 高 利 : 佩 雷 尔 曼 之 后 第 二 个 成 功 解 决 干 禧 年 数学 难题 的 人 。 

不 像 佩 雷 尔 曼 ， 她 局 兴 地 收 下 了 奖金 ， 并 将 其 中 一 部 分 (数额 未 知 〉 捐 
给 了 故乡 布拉格 的 大 学 作为 奖学金 。 


虽然 米 莱 娜 的 算法 在 理论 上 是 一 个 突破 ， 但 因为 实际 执行 时 间 过 长 而 缺 
之 实用 价值 。2017 年 ， 俄 罗斯 计算 机 科学 家 明 斯 元 : 波 洛 夫 采 用 一 种 巧 
妙 的 方法 改 展 了 米 莱 娜 的 算法 ， 从 而 大 幅 改 进 了 算法 的 执行 效率 ， 然 而 
还 是 不 够 实用 。 


一 年 后 在 中 国 ， 清 华 大 学 的 一 群 本 科 生 仔细 优化 了 明 斯 区 的 代码 ， 在 当 
时 世界 上 最 快 的 超级 计算 机 上 运行 它 。 他 们 在 几 天 之 内 就 解决 了 较 大 规 
模 的 团 问 题 和 其 他 几 个 季 见 的 NP 问 题 。 清 华 大 学 开始 与 波音 、 戴 姆 勒 - 
奔驰 等 工业 巨头 签约 ， 帮 助 这 些 公司 解决 一 些 棘 手 的 优化 问题 。 他 们 帮 
助 波 音 为 新 797 客 机 设计 出 了 更 好 的 机 避 ， 使 得 客机 能 直接 从 伦敦 飞 到 
悉尼 ， 


史 蒂 夫 :弗兰克 是 伊利 诺 伊 大 学 的 博士 生 ， 此 时 在 清华 做 一 学 期 的 访问 
学 者 ， 他 有 幸 参 与 了 项 目的 研究 工作 。 回 到 伊利 诺 伊 州 的 厄 巴 纳 后 ， 他 
向 导师 诉苦 ， 无 论 他 们 如 何 优化 ， 还 是 要 花 几 天 时 间 才 能 解决 一 个 中 等 
规模 的 NP 问 题 。 

“如 果 你 遇 到 灯 神 ， 它 能 满足 你 一 个 愿望 ， 你 会 许 什么 愿 ? ”导师 说 。 


“不 知道 。” 史 带 夫 回答 。 
































“让 它 给 你 一 个 能 满足 你 所 有 愿望 的 灯 神 ! ” 


史 带 夫 脑 中 一 亮 。 他 知道 一 定 存 在 一 个 能 更 好 解决 团 问题 的 算法 ， 而 他 
自己 想 不 出 这 个 算法 。 但 是 他 遇 到 了 灯 神 一 一 清华 的 代码 ， 他 可 以 用 很 
快 的 速度 搜索 指数 级 数量 的 可 能 算法 。 所 以 他 基于 清华 的 例 程 写 了 一 个 
搜索 更 好 的 NP 问题 算法 的 程序 。 他 获准 可 以 使 用 位 于 伊利 诺 伊 大 学 的 
国家 超级 计算 应 用 中 心 (NCSA) 的 计算 资源 。 经 过 几 周 的 计算 ， 他 的 
工作 初 见 成 效 。 他 找到 了 一 个 比 清华 的 算法 性 能 高 5% 的 算法 。 这 一 结 
果 发 篇 论文 红 绰 有 余 ， 但 不 会 产生 胡 动 效应 。 


他 的 导师 淡淡 地 说 :“ 用 新 算法 再 试 一 次 。” 


于 是 史 带 夫 用 他 的 新 算法 找到 了 一 个 更 快 的 解决 NP 问题 的 算法 。 几 周 
后 他 获得 了 20% 的 性 能 提升 。 


但 他 的 导师 还 不 满意 :“ 再 试 一 次 。” 


史 带 夫 这 样 回答 :“ 我 为 什么 不 编 个 程序 让 计算 机 自动 使 用 找到 的 算法 
来 得 找 更 好 的 算法 呢 ? ” 


导师 的 目光 变 得 异样 起 来 ， 仿 佛 在 说 你 终于 开 穷 了 ， 又 仿佛 在 将， 这么 
明显 的 事 你 怎么 现在 才 想 到 。 


史 蒂 夫 回 到 办 公 室 ， 开 始 写 一 个 算法 ， 让 计算 机 能 自动 利用 搜索 到 的 更 
快 的 算法 去 查找 比 当前 算法 更 快 的 算法 ， 这 样 一 直 找 下 去 ， 直 到 性 能 
法 提升 为 止 。 史 带 夫 的 一 个 同事 问 他 是 否 担心 天 网 效应 。 
“天 网 是 喻 ? ， 


“ 当 计 算 机 变 得 足够 聪明 ， 有 了 自我 意识 ， 它 束 会 接管 世界 ， 束 像 《 终 
结 者 》 系 列 电 影 里 的 超级 计算 机 ‘天 网 ;一 样 。” 


“不 ， 只 是 计算 机 代码 而 已 ， 不 用 担心 。” 
史 带 夫 写 好 了 代码 ， 最 后 一 次 在 NCSA 的 超级 计算 机 上 运行 它 。 随 着 友 


代 次 数 的 增加 ， 由 计算 机 自动 生成 的 求解 NP 问题 的 算法 性 能 变 得 越 来 
越 好 ， 最 后 在 停止 时 ， 生 成 了 一 个 有 4200 万 行 机 强人 码 的 让 人 费解 的 程 





























序 。 它 求解 NP 问题 的 速度 ， 那 是 相当 快 。 (顺便 说 一 句 ， 计 算 机 依然 
没有 上 自我 意识 。) 某 高 校 出 版 社 将 这 个 算法 自 树 地 称 为 “ 厄 巴 纳 算法 ”， 
后 来 这 个 名 字 被 保留 了 下 来 。 


伊利 诡 伊 大 学 的 数学 家 们 开始 率先 使 用 厄 巴 纳 算 法 ， 用 它 来 证 明 剩 下 的 
干 往年 数学 难题 。 证 明 过 程 是 计算 机 生成 的 ， 复 杂 到 人 类 几乎 无 法 理 
解 。 克 雷 数 学 研究 所 很 快 发 表 声明 ， 不 再 接受 基于 米 业 娜 :由 维尔 友 现 
的 百 万 美元 算法 衍生 出 来 的 任何 算法 的 数学 证 明 。 


许多 试图 以 许可 证 和 买 断 方 式 获得 尼 巴 纳 算法 的 公司 都 陷入 了 诉讼 泥 
潭 ， 因 为 与 算法 有 关 的 各 方 一 一 资助 米 羔 娜 研究 的 捷克 政府 、 史 带 夫 : 
弗兰克 、 史 蒂 夫 的 导师 以 及 NCSA， 都 主张 自己 对 厄 巴 纳 算法 的 所 有 
权 。 


世界 贸易 组 织 在 认识 到 该 算法 的 重大 意义 后 ， 要 求 公 开 厄 巴 纳 算法 ， 供 
全 人 类 共同 享用 ， 相 关 各 方 将 得 到 合理 的 补偿 ， 并 成 立 专门 委员 会 落 
实 。2019 年 10 月 23 日 ， 厄 巴 纳 算法 对 所 有 人 公开 了 。 


从 此 ， 世 界 发 生 了 一 系列 戏剧 性 的 变化 .…… 











2.2 计算 机 1， 冶 症 0 


海伦 的 医生 走 进 检查 室 ， 关 上 号 后 的 门 ， 说 :“ 我 有 个 坏 消息 ， 你 患 
胰腺 瘤 。” 


海伦 倒 抽 一 口 冷 气 。 她 才 43 岁 ， 家 里 有 三 个 孩子 ， 最 大 的 15 岁 ， 最 小 的 
才 6 岁 。“ 你 怎么 可 能 知道 ， 我 不 过 验 了 个 血 。” 


“我 们 现在 只 需要 得 到 血液 中 的 标记 物 和 DNA， 束 可 以 判断 你 是 否 患 有 
六 症 ， 是 哪 种 瘤 症 ， 以 及 六 变 的 程度 。 如 果 你 坚持 ， 我 们 可 以 做 活检 ， 
但 是 没 必要 冒 这 个 险 ， 现 有 的 检查 已 经 足够 精确 了 。” 


“我 的 表姐 在 8 年 前 被 诊断 出 胰腺 瘤 ， 那 会 儿 是 2018 年 。 当 时 这 病 没什么 
治疗 措施 ， 几 个 月 后 她 就 过 世 了 。” 


“ 季 好 医学 在 过 去 十 年 里 有 了 很 大 的 进步 。 我 们 意识 到 适合 所 有 人 的 搞 
总 方 法 疗效 有 限 ， 人 们 需要 针对 个 体 的 治疗 方案 ， 就 是 先 鉴 别 出 茶 个 人 
的 正常 DNA 和 癌 细 胞 的 突变 DNA， 然 后 制造 出 特定 的 和 蛋白质， 其 折 县 
方式 不 仅 能 有 效 地 饿 死 癌 细 胞 ， 而 且 对 正常 细胞 没有 任何 影响 。 死 亡 的 
六 细 胞 会 被 排出 体外 。” 


“ 听 起 来 会 很 贵 。 ”海伦 评论 道 
“化 疗 才 贵 呢 ， 这 种 疗法 的 成 本 只 有 几 千 美 元 ， 将 来 还 会 更 便宜 。 大 部 
分 费用 都 可 以 由 你 的 医疗 保险 支付 。” 

“大 好 了 ! 过 去 十 年 究竟 发 生 了 什么 ， 让 检验 和 治疗 变 得 如 此 简便 ?” 


“这 些 想法 很 早 就 有 了 ， 但 在 过 去 ， 即 使 是 世界 上 最 快 的 计算 机 在 解决 
DNA 密 码 方面 也 显得 太 慢 ， 所 以 一 直 没 有 什么 突破 。 厄 巴 纳 算 法 的 出 现 
改变 了 这 种 状况 ， 过 去 几 年 里 我 们 取得 了 难以 置信 的 进步 。 通 常 一 项 新 
技术 出 来 后 ， 我 们 会 做 很 多 年 实验 才 会 投入 临床 使 用 ， 但 是 这 种 疗法 的 
初期 调试 太 成 功 了 ， 以 至 于 FDA 和 觉得 不 立即 批准 投入 使 用 都 不 道德 ， 毕 
况 有 那么 多 的 六 症 患者 ， 他 们 等 不 起 。” 


“什么 时 候 开始 治疗 ? * 海 伦 问 。 



































“开始 ? 我 们 已 经 用 抽 的 血 做 完了 分 析 ， 这 是 你 的 处 方 。” 


医生 递 给 海伦 的 不 是 一 张 纸 ， 而 是 一 个 U 盘 。“ 这 里 面 有 治疗 你 的 考证 的 
重 白 质 的 编码 信息 。 把 它 带 到 药房 ， 让 他 们 为 你 制作 药片 。 一 天 一 片 ， 
连 吃 两 周 ， 你 体内 的 瘤 细胞 就 清扫 干净 了 ， 没 有 任何 副作用 。 但 是 要 注 
意 ， 这 个 处 方 只 对 你 起 作用 ， 其 他 人 的 DNA 不 同 ， 如 果 吃 了 你 的 药 厂 ， 
可 能 会 产生 严重 的 后 果 ， 甚 至 是 致命 的 。” 


“没有 副作用 ? 头发 不 会 掉 光 ? 没有 恶心 想 叶 的 感觉 ? 癌症 及 早 发 现 的 
话 只 要 服 几 片 药 就 好 了 ， 跟 治 感冒 一 样 ? 所 有 这 一 切 都 得 益 于 一 个 算 
法 ?” 


“不 完全 准确 ，” 医 生 说 ,，“ 没 错 ， 厄 巴 纳 算法 帮 人 们 战胜 了 冶 魔 ， 治 全 
了 蕊 滋 病 和 糖尿 病 。 可 和 是， 我 们 还 不 知道 如 何 应 对 普通 感冒 。” 














2.3 ”棒球 比赛 


“真是 打 棒 球 的 好 天 气 ! ” 兰 迪 对 他 12 罗 的 女儿 纠 特 说 ， 这 是 他 第 一 次 种 
女儿 到 秆 路易 斯 看 棱 球 比赛 。 对 路 易 斯 红 徐 队 主 场 对 战 密尔沃基 酿酒 

人 ， 这 场 2026 赛 季 末 的 夺冠 赛 扣人心弦 。 兰 迪 感 叹 棒球 运动 和 他 小 时 候 
相 比 变化 不 少 。 这 项 运动 在 科技 的 使 用 上 曾经 是 那么 地 原始 ， 甚 至 连 计 
时 装置 都 不 用 ， 而 如 今 它 同样 受到 了 龙 巴 纳 算法 的 巨大 影响 。 


首先 当然 是 棒球 赛程 安排 上 的 变化 。 直 到 2004 年 ， 棒 球 大 联盟 (Major 
League Baseball) 的 赛程 都 是 由 享 利 和 霍 莉 :斯 带 分 和 柠 夫 妇 来 安排 的 ， 这 
对 夫妻 档 安排 赛程 的 依据 是 几 条 简单 的 规则 ， 例 如 每 个 队 主场 和 客场 的 
比赛 数 最 好 大 致 相等 ， 还 会 照顾 某 些 地 方 的 偏好 ， 如 波士顿 的 球迷 希望 
把 波士顿 红 袜 队 的 一 次 主场 比赛 安排 在 四 月 中 旬 爱 国 者 日 的 日 天 ， 因 为 
波士顿 马拉松 赛 的 参赛 人 员 会 在 那天 从 球场 劳 边 经 过 。2005 年 棒球 大 联 
盟 与 匹兹堡 的 赛事 筹划 集团 (Sports Scheduling Group ) 签订 了 合作 协 
议 ， 因 为 这 家 公司 知道 如 何 避 人 免 两 文 队 伍 在 连续 的 几 周 内 多 次 交锋 。 众 
所 周知 ， 骏 雨天 气 无 法 进行 室外 棒球 赛 ， 但 赛事 筹划 集团 在 安排 赛事 时 
从 不 考虑 下 雨 的 因素 ， 原 因 很 简单 ， 没 办 法 在 开 客 前 的 12 月 份 预 测 整个 
赛季 的 天 气 状况 。 当 然 ， 那 是 尼 巴 纳 算法 出 现 之 前 的 事情 了 。 


在 算法 的 帮助 下 ， 人 类 的 天 气 预测 技术 取得 了 不 可 思议 的 进步 ， 可 以 提 
前 一 年 准确 预测 温度 、 风 力 、 云 量 和 降水 。 类 似 的 算法 可 以 做 到 准确 预 
测 风 骏 、 龙 卷 风 和 飓风 ， 让 人 们 有 充足 的 准备 和 撤离 时 间 。 新 的 天 气 预 
测 技 术 同 样 改变 了 人 们 的 日 常生 活 。 学 校 会 对 未 来 下 雪 的 日 子 提前 做 准 
备 。 承 办 户外 婚礼 的 教堂 会 根据 未 来 婚期 的 天 气 状况 回 新 人 收取 不 同 的 
费用 ， 想 在 好 天 气 结婚 的 要 多 交 钱 ， 愿 意 在 炎热 、 潮 湿 或 下 雨天 举行 露 
天 婚礼 的 则 可 以 胖 受 折扣 。 大 多 数 人 都 想 在 好 天 人 气 看 棒球 赛 ， 所 以 如 果 
底特律 会 下 雨 或 者 阴 天 的 话 ， 完 全 可 以 把 比赛 安排 到 明 尼 阿 波 利 斯 去 ， 
那里 将 艳阳 高 照 。 


赛场 和 电视 机 前 的 观众 都 想 看 到 高 质量 的 比赛 ， 尤 其 是 临近 赛季 末尾 时 
优秀 球 队 之 间 的 激烈 比拼 。 兰 迪 小 时 候 ， 判 断 哪 文 球 队 会 赢 没 有 科学 的 
方法 ， 基 本 靠 猜 。 而 新 的 预测 工具 料 事 如 神 ， 能 提前 告诉 人 们 哪些 球 队 
将 进入 9 月 份 的 冠军 争夺 赛 。 计 算 机 预测 胜 场 也 并 非 完全 准确 。 棒 球 运 
动 具有 随机 性 ， 每 个 赛季 的 实际 战局 都 会 与 预测 有 那么 几 场 的 出 入 。 然 












































而 算法 的 模型 仍 能 以 极 高 的 准确 率 预 测 哪些 球 队 会 在 赛季 末尾 名 列 前 
茜 。 那 些 没 被 预测 为 桂冠 热门 的 球 队 的 球迷 们 每 年 都 会 抱怨 计算 机 算 错 
了 ， 然 而 计算 机 通 第 是 对 的 ， 唯 一 的 一 次 预测 失败 ， 被 人 们 津 妇 乐 道 。 


棒球 产业 的 大 至 们 想 用 更 好 的 方式 安排 比赛 ， 目 标 之 一 是 让 每 个 人 都 能 
在 最 好 的 天 气 看 到 强 队 之 间 的 火拼 ， 当 然 还 有 更 实际 的 成 本 控制 方面 的 
诉求 ， 比 如 尽 可 能 缩短 每 个 团队 花 在 路 上 的 总 时 间 。15 年 前 ， 根 本 不 可 
能 将 很 多 方面 纳入 考虑 ， 那 会 使 需要 检验 的 计划 规模 庞大 得 难以 处 理 。 
但 现在 ， 无 论 要 求 多 么 苛刻 ， 尼 巴 纳 算法 都 能 在 几 分 钟 内 给 出 一 个 最 棒 
的 赛程 表 。 


所 以 兰 迪 才能 在 这 样 完 美的 天 气 带 山 特 去 看 这 样 一 场 关 键 的 棒球 赛 。 虽 
然 这 天 红 省 队 的 观 赛 费用 比 平 时 高 ， 但 兰 迪 很 乐意 为 此 买单 。 


兰 迪 和 凯特 进入 看 台 的 时 候 没 有 检票 员 和 检票 闸 机， 他 们 残 且 接 走 进 了 
体育 场 ， 监 控 摄 像 头 通过 人 脸 识 别 软件 认 出 了 人 他们， 通过 数据 匹配 证 实 
他 们 已 经 买 过 票 了 了 。 如 果 有 人 企图 不 买 紧 就 进 场 ， 保 安 肯 定 会 找 出 他 ， 
人 们 很 早 束 知 道 了 这 一 事实 ， 不 敢 冒 险 去 挑战 识别 软件 的 威力 了 。 


兰 迪 和 女儿 就 座 后 ， 兰 迪 四 处 打量 ， 发 现 僧 大 的 球场 空空 荡 荡 ， 看 不 到 
儿 年 前 巨大 的 电视 摄像 机 和 操作 员 了 。 取 代 这 些 的 是 围绕 在 球场 周围 的 
20 台 小 得 几乎 看 不 见 的 摄影 机 。20 台 摄像 机 的 画面 输入 计算 机 后 ， 软 件 
利用 厄 巴 纳 算法 构建 出 比赛 的 实时 三 维 演 染 数据 。 从 这 些 泻 染 数据 中 ， 
计算 机 可 以 合成 从 任意 角度 拍摄 球场 任意 地 点 的 视频 短片 。 观 众 能 从 捕 
手 的 视角 观看 比赛 ， 也 能 从 跑 垒 员 的 视角 观看 他 滑 同 三 垒 的 英姿 。 虽 然 
这 些 男 面 其 实 是 计算 机 合成 的 ， 但 看 起 来 非 党 逼真。 在 一 次 有 名 的 实验 
中 ， 请 100 个 观众 观看 并 排放 在 一 起 的 两 个 短片 ， 其 中 一 个 短片 是 实际 
拍摄 的 ， 另 一 个 是 计算 机 合成 的 。 结 果 89 人 都 误 以 为 计算 机 合成 的 短片 
征 实际 拍摄 的 。 


新 型 电视 允许 人 们 直接 下 载 三 维 泻 染 数据 ， 然 后 控制 虚拟 的 摄像 机 飞 到 
赛场 上 的 任意 位 置 ， 随 心 所 欲 地 享受 比赛 过 程 。 


计算 机 在 球 棒 击 球 的 那 一 瞬间 ， 准 确 预测 出 球 的 飞行 轨迹 ， 然 后 立即 选 
一 个 最 佳 的 观看 角度 ， 把 比赛 实时 呈现 出 来 。 运 营 电视 网 络 转播 的 只 有 
四 个 人 : 两 个 评论 员 ， 一 个 制 片 人 ， 还 有 一 个 技术 员 【 处 理 侦 发 的 故 
障 ) 。 评 论 员 说 的 是 英语 ， 而 由 于 半路 易 斯 和 密尔沃基 两 队 分 别 有 一 个 


























知名 的 日 本 球员 ， 这 场 比赛 在 东京 也 很 受 关注 ， 那 里 的 观众 听 到 的 将 是 
日 语 的 评论 。 实 际 上 日 本 观众 听 到 的 是 美国 的 评论 员 在 说 话 ， 但 是 计算 
机 立即 用 语音 识别 、 翻 译 和 语音 合成 工具 模拟 出 地 道 的 日 语 。 这 些 工具 
自然 也 使 用 了 厄 巴 纳 算法 。 这 场 比赛 在 全 世界 用 876 种 语言 和 方言 播 
出 。 


转播 一 场 比赛 用 四 个 人 似乎 已 经 很 少 了 ， 但 在 电视 网 络 的 副 总 裁 看 来 ， 

最 好 一 个 人 都 不 用 。 几 年 以 来 ， 大 学 校园 都 通过 布置 在 球场 周围 的 摄像 
机 记录 练习 赛 ， 供 教练 们 进行 战术 分 析 。 最 近 ， 一 个 具有 创业 精神 的 学 
生成 功 地 将 厄 巴 纳 算法 应 用 到 这 些 录 像 数 据 上 ， 制 作出 全 套 的 转播 视 

频 ， 其 中 评论 、 特 写 视 角 、 数 据 统计 样 样 俱全 ， 一 切 完 全 由 计算 机 自动 
生成 。 很 快 所 有 大 学 《以 及 许多 高 中 比赛 和 小 型 联赛 ) 的 每 种 运动 赛事 
都 可 以 在 互联 网 上 实时 观看 ， 还 拥有 各 种 语言 的 版 本 。 这 些 转 播 的 质量 
也 许 比 不 上 真人 做 评论 的 那些 节目 ， 但 也 差 不 到 哪里 去 。 


巴 想 比赛 达到 了 前 所 未 有 的 高 度 。 计 算 机 可 以 生成 体育 迷 们 梦想 中 看 到 
的 比赛 ， 不 仅 可 以 让 不 在 一 支 球 队 的 球星 们 并 屑 作战 ， 甚 至 还 可 以 关公 
战 秦 琼 ， 让 活跃 在 不 同时 代 的 球星 同 场 兑 搁 : 让 全 盛 时 期 的 传奇 投手 赛 
杨 对 战 如 日 中 天 的 乔 : 狐 马 乔 ， 或 是 1927 年 的 洋基 队 对 战 1998 年 的 洋基 
队 。 纠 想 与 现实 变 得 难以 区 分 。 某 个 患 人 节 ，ESPN 电 视 台 的 一 个 计算 
机 程序 员 改 写 了 部 分 代码 ， 让 电视 机 前 的 观众 看 到 他 所 喜爱 的 波士顿 翅 
尔 特 人 队 打 败 了 纽约 尼克 斯 队 ， 而 现实 比赛 中 ， 尼 克 斯 才 是 真正 的 胜 

者 。 这 次 转播 事故 让 许多 人 于 了 饭碗 。 


计算 机 充当 裁判 也 表现 完美 ， 它 总 能 精准 无 误 地 判别 坏 球 、 好 球 、 出 局 
和 全 人 垒 打 。 为 了 削减 成 本 ， 小 型 联赛 和 大 学 里 的 所 有 比赛 都 用 计算 机 来 
做 裁判 。 而 大 型 联赛 坚持 使 用 真人 裁判 ， 每 当 错 误 的 判决 改变 比赛 的 局 
势 都 会 遭 到 一 片 质 疑 之 声 。 


由 于 担心 计算 机 做 管理 工作 也 比 人 类 经 理 更 为 出 色 《〈 这 种 担心 是 正确 
的 ) ， 棒 球 大 联盟 在 经 历 过 2022 年 世界 巡回 赛 的 失败 之 后 ， 宣 布 蔡 止 球 
队 使 用 计算 机 设备 。 人 负责 人 称 : “这 是 为 了 棒球 运动 好 。” 


兰 迪 一 边 喝 厦 啤酒 一 边 嘲 着 汉堡 (饮料 和 食物 变 得 更 好 吃 了 ， 因 为 尼 巴 
纳 算 法 改进 了 配方 ) ， 一 边 还 欣赏 者 比赛 。 比 赛 进行 的 方式 和 他 小 的 时 
候 相 比 没有 什么 变化 。 他 其 实 完 全 可 以 省 下 大 笔 钱 ， 在 家 里 欣 茹 从 完美 





























视角 呈现 的 比赛 三 维 实况 转播 。 尽 管 科 技 让 在 家 看 球 的 体验 远 比 在 体育 
场 看 球 还 要 好 ， 兰 迪 还 是 愿意 至 受 一 种 参与 感 ， 尼 巴 纳 算法 再 厉害 也 无 
法 再 现 这 种 感情 上 的 依恋 。 


计算 机 可 以 自动 生成 计 分 表 ， 但 兰 迪 还 是 教 女儿 凯特 怎样 在 纸 上 计 分 ， 
就 像 他 父亲 教 他 的 那样 。 纵 使 以 万 巴 纳 算法 为 代表 的 科技 改变 了 几乎 所 
有 的 事物 ， 但 比赛 还 是 那个 比赛 。 三 振 出 局 的 老 规 矩 ， 永 远 都 不 会 改 








2.4 奥 卡 姆 剃刀 


为 何 形 式 简 单 的 计算 机 代码 ， 只 要 强大 到 龙 巴 纳 算 法 那 种 级 别 ， 就 能 带 
给 我 们 一 个 理想 的 世界 ， 让 人 们 可 以 治 印 疾病、 预测 天 气 ， 以 及 创造 几 
乎 能 够 以 假 乱 真 的 虚拟 环境 ? 为 了 回答 这 个 问题 ， 我 们 需要 回 到 14 世 纪 
的 早期 。 


奥 卡 姆 的 威廉 还 是 一 名 青年 时 就 加 入 了 英国 的 方 济 各 会 。 和 许多 14 世 纪 
的 军 教 团体 一 样 ， 方 济 各 会 的 总 部 设 在 牛津 ， 它 为 牛津 大 学 的 在 校生 提 
供 了 住所 。 威 廉 是 一 名 主 修神 学 的 牛津 学 生 ， 尽 管 没有 毕业 ， 他 后 来 还 
是 成 了 中 世纪 最 主要 的 思想 家 之 一 ， 对 物理 学 、 神 学 、 逻 辑 学 和 哲学 都 
作出 了 巨大 贡献 。 他 最 著名 的 思想 是 奥 卡 姆 闲 刀 法 则 ， 即 主张 最 简单 的 
解释 通常 是 最 好 的 解释 。“ 刹 刀 ” 一 词 比 喻 我 们 可 以 把 一 个 理论 中 纠缠 复 
杂 的 部 分 像 衣 子 一 样 “ 剃 除 ”， 只 留 下 最 简单 的 解释 。 这 一 思想 贯穿 文艺 
复兴 时 代 一 下 延续 到 今天 ， 引 领 着 一 代 又 一 代 人 的 科学 和 哲学 思 湖 。 


17 世 纪 法 国 哲 学 家 勒 内 : 符 卡 儿 通 晓 奥 卡 姆 剃刀 法 则 。 他 怀疑 一 切 ， 甚 
至 对 周围 世界 的 存在 性 提出 质疑 。 稍 卡 儿 最 为 音 名 的 哲学 命题 是 Cogito 
ergo sum， 即 “我 思 故 我 在 ”。 在 他 的 音 作 《方法 论 》 中 ， 人 第 卡 尔 据 弃 了 
一 切 前 提 假 设 ， 仅 从 他 能 通过 思考 意识 到 自己 这 一 点 ， 得 出 了 “ 篆 卡 尔 
是 存在 的 ”这 一 结论 。 那 么 笛 卡 尔 如 何 解 释 他 感受 到 的 复杂 世界 呢 ? 万 
物 是 否 有 可 能 只 存在 于 笛 卡 尔 的 意识 中 ? 第 卡 儿 不 赞同 这 种 想法 ， 因 为 
有 男 一 种 更 简单 和 更 合理 的 解释 ， 那 就 是 其 他 人 和 他 一 样 ， 大 家 共同 生 
活 在 一 个 可 以 认 知 和 理解 的 物质 世界 之 中 。 


我 被 “我 思 故 我 在 ?这 几 个 字 迷 住 了 ， 我 确信 它 是 真理 ， 证 据 只 有 一 
条 ， 那 就 是 我 清楚 地 看 到 ， 人 存在 是 一 个 事物 能 够 思辩 的 必要 前 提 。 我 
甚至 可 以 论断 ， 一 般 地 讲 ， 一 切 我 们 能 清晰 明确 地 在 脑 中 显现 的 事物 
都 是 真实 的 。 然 而 值得 注意 的 问题 是 ， 很 难 恰当 地 分 辨 哪些 物体 是 我 
们 能 够 明确 地 想象 的 。 

















箔 卡 儿 ，《 方 法 论 》， 第 四 部 分 


和 笛 卡 儿 同 时 代 的 约 鞭 内 斯 : 开 普 勒 通过 观测 行星 运动 ， 归 纳 出 了 一 系 
列 描述 它们 运动 路 线 和 速度 的 定律 。 至 于 为 什么 行星 运动 符合 这 些 定 








律 ， 开 普 勒 无 法 给 出 一 个 简单 的 解释 。 


艾 酝 克 : 牛 顿 将 奥 卡 姆 弟 刀 法 则 运用 到 物理 世界 。 他 著名 的 运动 定律 以 
非常 简单 的 方式 ， 表 述 了 物体 如 何 相互 作用 : 


1. 如 宋 不 给 物体 施加 任何 力 ， 静 止 的 物体 会 保持 静止 ， 运 动 的 物体 速 
度 保持 不 变 ; 

2. 施加 于 物体 上 的 力 将 产生 一 个 与 其 大 小 成 正比 的 固定 加 速度 ; 

3. 一 个 物体 给 为 一 个 物体 施加 力 ， 则 施 力 物 体 也 会 受到 来 日 受 力 物 体 
的 大 小 相等 、 方 向 相反 的 力 。 


通过 把 运动 定律 和 他 对 引力 的 简单 描述 相 结 合 ， 牛 顿 展示 了 如 何 从 天 体 
的 运动 推导 出 开 普 勒 定律 。 简 单 的 表述 可 以 具有 强大 的 解释 能 力 。 


几 个 世纪 后 ， 阿 尔 伯 特 : 爱 因 斯 坦 和 其 他 科学 家 从 理论 上 提出 : 对 于 运 
动 速度 接近 光速 的 物体 ， 牛 顿 的 简单 运动 定律 是 不 成 并 的 。 后 来 的 一 些 
实验 基本 证 明 爱 因 斯 坦 是 对 的 。 他 的 名 言 是 :“ 把 所 有 事 都 变 得 尽 可 能 
简单 ， 而 不 可 过 于 简单 。” 这 并 不 意味 独 牛 顿 错 了 ， 人 恰恰 相反 ， 他 的 模 
型 是 对 我 们 所 认 知 的 世界 的 一 个 很 好 的 近似 。 甚 至 在 今天 ， 对 于 包括 驾 
驶 汽车 ， 以 及 高 中 大 部 分 科学 实验 在 内 的 一 些 简 单 场合 ， 牛 顿 定律 仍然 
非常 适用 。 


对 于 非常 小 的 粒子 ， 甚 至 爱 因 斯 坦 的 理论 也 不 再 成 立 ， 它 们 所 服从 的 法 
则 被 称 为 量子 力学 。 当 代 物 理学 家 试图 找到 一 种 能 融合 爱 因 斯 坦 的 广义 
相对 论 和 量子 力学 的 理论 ， 即 所 谓 的 “大 统一 理论 ”。 


简单 的 模型 永远 无 法 反映 世界 全 部 的 复杂 性 ， 但 它们 通常 可 以 很 接近 这 
个 目标 。 为 某 些 情 形 找到 一 种 简单 的 解释 ， 就 能 对 未 来 发 生 的 类 似 情形 
做 出 很 好 的 预测 。 近 年 来 我 们 看 到 这 个 原理 在 计算 机 科学 世界 得 到 了 充 
分 的 体现 。 


今天 我 可 以 手写 一 张 文 票 ， 用 手机 拍 张 文 票 的 照片 ， 然 后 通过 互联 网 存 
入 文 票 。 银 行 的 软件 通过 照片 就 能 识别 交易 金额 和 账号 ， 即 使 文 票 是 手 
写 的 也 没关系 。 如 果 没 有 疑 议 ， 银 行 职员 甚至 都 不 用 杀 目 去 看 这 张 文 
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识别 位 于 支取 底部 的 账号 比较 容易 ， 组 成 账号 的 数字 符合 固定 的 格式 ， 
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这 是 特意 为 方便 计算 机 识别 而 设计 的 。 


但 是 支票 上 的 金额 是 手写 的 "30 美元”。 每 个 人 写字 的 方式 都 不 一 样 ， 计 
算 机 如 何 能 判别 这 张 文 桶 的 金额 呢 ? 
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图 2-1 支票 
这 个 问题 不 简单 。 不 信 你 看 数字 2 有 多 少 种 写法 。 
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HPL UU 
和 和 bb 和 


图 2-2 各 种 手写 的 数字 2 


计算 机 科学 的 一 个 分 文 一 一 机 器 学 习 就 是 处 理 这 类 问题 的 。 首 先 用 大 量 
的 数据 训练 一 个 算法 ， 在 这 个 例子 里 ， 数 据 就 是 人 们 写 数字 2 和 其 他 数 
字 的 样 例 。 算 法 会 建立 一 个 相对 简单 的 模型 ， 然 后 尝试 用 这 个 模型 正确 
区 分 各 种 手写 的 数字 。 训 练 得 好 的 算法 能 对 新 的 数字 进行 正确 的 分 类 ， 
即使 是 对 训练 期 之 后 写 出 的 数字 也 不 例外 。 


过 去 20 年 ， 计 算 机 科学 家 在 机 器 学 习 领 域 取 得 了 长 足 的 进步 ， 研 究 出 了 
通过 检查 几 生 到 几 百 万 样 例 ， 计 算出 将 数据 分 类 的 正确 方式 。 除 了 识别 
支 昧 之 外 ， 许 多 照片 处 理 程序 还 可 以 根据 人 脸 来 对 照片 排序 ， 效 果 还 过 








得 去 。Amazon、Netflix 和 了 Pandora 等 公司 能 为 顾客 推荐 图 书 、 电 影 和 音 
乐 ， 根 据 的 是 顾客 之 前 购买 过 的 商品 ， 以 及 观 影 和 上 听 歌 的 模式 。 语 音 识 
别 和 语言 翻译 虽然 不 能 做 到 和 真人 一 样 ， 但 会 让 你 大 致 了 解 写 的 或 说 的 
是 什么 。 垃 圾 邮件 识别 工具 屏蔽 了 人 们 不 想 要 的 几乎 所 有 信息 。 到 2020 
年 ， 所 有 的 汽车 有 望 能 够 自动 驾驶 。 


这 类 技术 所 能 做 到 的 差不多 惑 是 这 些 了， 未 来 取得 的 进步 最 终 将 越 变 越 
小 。 这 是 否 意 味 看 奥 卡 姆 钉 思 不 再 锋利 ， 宇 刀 已 老 ? 


倒 也 未 必 。 奥 卡 姆 刹 刀 法 则 说 的 是 最 简单 的 解释 问题 的 方法 整 是 最 好 的 
方法 ， 但 它 并 没有 告诉 你 如 何 找到 那个 最 简 表述 。 如 今 的 机 器 学 习 技 术 
只 能 使 用 简单 的 数据 表述 方式 ， 通 常会 把 数据 的 多 种 特征 用 相对 直接 的 
方式 加 以 合并 。 如 何 找到 最 简 表 述 ， 即 找到 任意 形式 的 程序 中 最 短小 而 
有 效 的 数据 分 类 程序 ， 是 一 个 困难 的 问题 ， 一 个 NP 问题 。 


如 果 能 使 用 快速 解决 所 有 NP 问题 的 尼 巴 纳 算法 ， 找 到 最 简 蛙 的 数据 分 
类 程序 就 变 成 了 一 道 简 单 的 编程 练习 。 我 们 需要 做 的 只 是 把 海量 数据 交 
给 算法 ， 然 后 看 着 它 完成 剩 下 的 工作 。 这 样 一 来 ， 我 们 几乎 能 了 解 所 有 
的 事物 。 


我 们 已 经 看 到 了 厄 巴 纳 算法 帮助 人 类 治 龟 了 很 多 疾病 ， 并 且 改 变 了 美国 
的 棒球 运动 。 接 下 来 让 我 们 回 到 未 来 ， 看 看 它 是 如 何 改变 艺术 的 。 



































2.5 创造 力 的 目 动 化 


借助 奥 卡 姆 剃刀 ， 所 巴 纳 算 法 几乎 能 让 我 们 了 解 一 切 ， 包 括 艺 术 作品 为 
何 优秀 ， 音 乐 为 何 流行 ， 言 语 为 何 动人 心 昕 。 要 知道 P=NP 意 味 者 只 要 
能 评测 一 个 事物 ， 我 们 就 能 找到 它 。 所 以 只 要 有 一 个 慧眼 识 珠 的 算法 ， 
再 用 厄 巴 纳 算 法 就 能 很 快 找到 这 颗 “ 明 珠 ”。 


2022 年 ， 美 国民 主 党 总 统 候选 人 初 选 即将 在 科罗拉多 州 开 始 。 之 前 的 两 
周 ， 皮 特约 办 逊 得 紧 第 三 ， 远 远 落 后 于 前 两 名 。 情 况 在 “ 那 次 演讲 ”后 
改变 了 。 在 书 尔 市 的 一 个 小 剧场 里 ， 约 险 逊 进行 了 一 次 短 短 10 分 钟 的 演 
讲 ， 其 至 没有 媒体 列席 。 然 而 这 次 有 关 科 罗拉 多 和 美国 的 演讲 格外 动人 
心 蜡 ， 在场 的 32 个 人 起 并 报 以 热烈 的 掌声 。 


-个 与 会 者 用 手机 录 下 了 演讲 ， 发 到 了 网 上 。 几 百 万 人 在 线 观 看 了 演 
讲 ， 后 来 甚至 有 几 千 人 言 之 首 首 ， 说 目 己 杀 临 了 那 次 演讲 。 约 办 逊 记得 
了 初 选 ， 成 为 2024 年 总 统 竞 选 的 热门 候选 人 。 为 进一步 提高 自己 的 曝光 
率 ， 皮 特约 翰 进 炒 了 自己 的 竞选 经 理 ， 然 后 换 了 一 个 享誉 全 国 的 专 
家 。 











被 炒 的 前 苋 选 经 理 分 念 不 平 ， 召 开 记 者 会 爆料 了 那 次 演讲 背后 的 真相 。 
当时 情况 不 妙 ， 如 果 不 马 上 使 出 一 些 厉 害 手段 ， 皮 特 : 约 鞠 还 的 竞选 之 
旅 眼看 就 要 到 头 了 。 于 是 ， 竞 选 经 理 雇 了 一 个 计算 机 程序 员 ， 程 序 员 先 
下 载 了 数 以 万 计 的 近 几 十 年 来 广 受 欢迎 的 演讲 ， 然 后 用 尼 巴 纳 算法 生成 
本 一 个 关于 科罗拉多 及 国内 外 局 势 的 优秀 演讲 稳 。 皮 特约 鞭 进 经 过 多 

次 排练 ， 把 计算 机 生成 的 稿子 背 得 深 瓜 烂熟 ， 然 后 才 有 了 韦 尔 市 的 演 

讲 。 苋 选 经 理 请 观众 把 此 次 记者 会 的 录像 也 传 到 网 上 。 


与 论 一片 哗 然 。 有 些 人 表示 慎 慨 ， 另 一 些 则 认为 政客 们 的 演讲 稿 是 由 职 
业 扎 稿 人 捉 帮 还 是 由 计算 机 生成 没 多 大 差别 。 皮 特约 只 逊 失 卸 了 民 
心 ， 也 失掉 了 大 选 。 到 2026 年 的 时 候 ， 几 乎 所 有 候选 人 撰写 演讲 稳 时 都 
会 让 计算 机 帮 屏 甚至 代 邢 ， 大 家 习以为常 ， 见 怪 不 怪 。 当 然 ， 人 人 演讲 
出 色 ， 等 于 没 人 演讲 出 色 。 


古典 音乐 家 用 厄 巴 纳 算法 完成 大 师 们 未 完成 的 名 作 ， 如 普 奖 尼 的 歌剧 
《图 兰 休 》、 马 勒 的 《第 十 交响 曲 》、 舒 伯 特 的 《第 八 交 响 曲 》 (又 名 








《未 完成 交 啊 曲 》) ; 而 且 还 能 再 续 经 典 ， 如 创作 出 贝多 芬 的 第 十 部 交 
啊 曲 。 由 算法 生成 的 最 著名 的 交 啊 曲 叫做 《 厄 巴 纳 第 一 交 啊 曲 》， 上 古典 
乐 迷 非常 喜爱 它 。 有 人 甚至 用 厄 巴 纳 算法 制作 出 甲壳 虫 和 猫 王 的 新 专 

辑 ， 将 已 故 歌星 们 的 嗓音 模仿 得 惟妙惟肖 。 音 乐 评论 界 的 专家 对 这 

些 “ 作 品 ? 哈 之 以 时 ， 认 为 它们 只 是 照 猫 画 席 ， 缺 乏 真 正 的 创意 ， 但 还 是 
有 很 多 人 下 载 。 


还 有 人 用 计算 机 生成 新 的 画作 、 小 说 、 戏 剧 和 诗歌 。 一 个 电影 爱好 者 最 
近 制 作 了 一 部 由 盛 年 的 享 弗 沫 ' 鲍 时 和 条 莉 娅 :多 们 次 主 泪 的 爱情 喜剧 
请 ， 看 起 来 束 好 像 两 人 真 的 穿越 了 时 光 ， 在 片场 大 诡 感 情 戏 一 样 。 想 看 
由 导演 带 姆 :但 顿 执 镜 的 《绿野仙踪 》? 没 问 题 ! 


Amazon 能 做 的 超越 了 原来 的 图 书 推荐 。 你 只 要 花 一 张 电 影 如 的 钱 ， 惑 
可 以 让 Amazon 写 一 部 完全 符合 你 口味 的 小 说 。NBC 电 视 台 目前 推出 了 
一 档 “ 现 场 直 播 ” 的 动作 冒险 剧 集 ， 完 全 由 计算 机 创作 ， 不 需要 任何 编剧 
和 演员 。 了 节 新 的 Xbox 上 的 电子 游戏 融 给 你 沉浸 式 的 叙事 和 世界 体验 。 
故事 的 发 展 不 再 是 线性 的 ， 而 是 有 着 无 限 的 可 能 性 ， 玩 家 完全 按 目 由 总 
志 行 动 ， 并 为 自己 的 行为 承担 相应 的 后 果 。 不 少 人 觉得 难以 区 分 游戏 和 
现实 生活 ， 比 较 明 显 的 区 别 是 现实 生活 可 能 没有 游戏 那么 刺激 。 


这 些 新 的 娱乐 选择 让 世人 目眩 神 迷 ， 为 之 痴狂 。 许 多 文章 部 在 批判 真实 
表达 的 缺失 。 究 葛 厄 巴 纳 算法 标志 着 一 个 艺术 新 纪元 的 诞生 ， 还 是 人 类 
创造 力 的 死亡 ， 这 在 未 来 的 几 个 世纪 仍 是 一 个 争议 不 断 的 话题 。 
































2.6 终极 侦探 


司法 机 关 觉 得 尼 巴 纳 算法 在 侦破 犯罪 案件 方面 堪 称 鬼才 ， 它 在 退 捕 嫌犯 
时 总 是 能 完成 不 可 能 完成 的 任务 。 然 而 也 有 一 些 争 议 。 


后 厄 巴 纳 算 法 时 代 的 亚特兰大 出 现 了 一 起 多 人 死亡 的 凶杀 案 ， 和 警方 从 犯 
罪 现场 的 快餐 包装 纸 上 收 集 到 了 一 份 DNA， 但 在 美国 DNA 联 合 索 引 系 
统 (CODIS) 中 找 不 到 与 之 匹配 的 数据 。 佐 治 亚 理 工学 院 的 一 个 计算 机 
科学 家 用 万 巴 纳 算 法 和 CODIS 创 建 了 一 个 新 的 程序 ， 该 程序 不 仅 可 以 利 
用 这 些 DNA 数 据 预测 嫌 犯 的 身高 、 眼 睛 和 皮肤 颜色 等 外 貌 特 征 ， 还 能 预 
测 嫌 犯 的 个 性 特点 以 及 可 能 从 事 的 行业 。 然 后 这 个 计算 机 科学 家 带领 学 
生 ， 把 CODIS 中 的 DNA 数 据 和 这 些 人 的 面部 照片 匹配 ， 从 而 研发 出 一 种 
技术 ， 根 据 某 人 的 DNA 生 成 相貌 的 大 致 素 描 ， 前 提 是 知道 目标 的 年 龄 和 
面部 毛发 类 型 。 


于 是 警方 想 用 这 个 算法 找到 和 犯罪 现场 DNA 匹 配 的 罪犯 头像 照片 ， 但 没 
有 成 功 。 他 们 又 把 算法 运行 在 驾驶 执照 的 头像 数据 库 里 ， 这 回 找到 了 一 
个 嫌疑 人 一 一 乔治 : 布 明 ， 几 小 时 后 把 他 抓 了 进来 。 弄 治 : 布 明 没有 不 在 

场 的 证 明 ， 而 且 是 唯一 符合 由 DNA 生 成 的 相 舰 素描 的 人 ， 但 除 此 之 外 ， 

没有 发 现 他 与 此 次 犯罪 有 明显 关联 。 他 拒绝 提供 DNA 样 本 ， 警 方 得 到 了 
法 院 的 搜查 令 ， 然 后 比 对 了 他 和 犯罪 现场 留 下 的 DNA， 有 果然 相符 。 开 治 
' 布 明 被 认定 有 徘 ， 判 处 死刑 。 


布 明 提出 上 诉 ， 他 的 律师 说 根据 犯罪 现场 留 下 的 DNA 画 出 素描 的 行为 侵 
犯 了 乔治 - 布 明 的 隐私 权 。 美 国 最 高 法 院 裁定 ， 使 用 DNA 判 定 一 个 人 的 
吴 份 是 合法 的 。 和 警方 只 是 将 算法 运行 在 合法 取得 的 证 据 上 。 


然而 ， 此 案 引 及 了 公众 对 素 失 隐 私 权 的 大 规模 抗议 。38 个 州 决定 DNA 只 
能 用 来 匹配 合法 收录 到 CODIS 中 的 嫌犯 ， 除 此 之 外 不 能 使 用 。 最 后 ， 佐 
治 亚 州 州长 将 乔治 :布朗 的 死刑 改判 为 终身 监禁 。 














2.7 美妙 世界 的 阴暗 面 


以 前 人 们 依靠 公 钥 加 密 技 术 ， 可 以 不 经 过 初始 化 设置 就 安全 地 通过 网 络 
将 信用 卡号 传 给 交易 公司 。 而 尼 巴 纳 算法 能 在 瞬间 破解 公 钥 加 密 。 起 

初 ， 电 子 商务 的 发 展 经 历 了 一 些 挫折 ， 但 互联 网 巨头 们 很 快 就 联合 起 

来 ， 将 业务 迁移 到 使 用 私 钥 加 密 的 系统 。 很 快 一 个 私 钥 注册 处 被 建立 起 
来 ， 人 们 从 街 边 的 药店 就 能 买 到 一 个 密 钥 U 盘 ， 里 面 装 着 几 十 亿 个 一 次 
性 的 私 铀 。 虽 然 比 原来 稍 显 不 便 ， 但 是 电子 商务 活动 义 兴 旺 起 来 。 


更 多 人 感到 个 人 隐私 被 剥 村 ， 并 对 此 感到 恐 惰 。 原 来 看 起 来 人 畜 无 害 的 
视频 摄像 尖 突 然 能 识别 和 人 退 踪 每 个 人 了 。 更 恐怖 的 是 ， 计 算 机 算法 能 准 
确 预 测 你 走 哪 条 路 ， 听 什么 歌 ， 看 什么 电影 ， 买 什么 产品 ， 简 直 比 你 自 
己 还 了 解 你 。 定 同 投 放 的 广告 很 容易 就 能 诱导 你 改变 消费 习惯 。 科 认为 
可 能 是 鳃 贼 或 到 怖 分 子 的 人 会 立刻 被 系统 认 出 来 ， 受 到 严密 的 监视 。 


对 尼 巴 纳 算法 最 大 的 顾虑 是 就 业 问 题 。 从 秘书 到 中 层 管理 人 员 ， 几 乎 所 
有 的 白领 职位 都 受到 算法 的 威胁 ， 它 可 以 理解 各 种 信息 《甚至 包括 不 太 
正式 的 电子 邮件 、 音 频 和 视频 ) ， 生 成 信件 和 报表 ， 还 能 根据 分 析 得 出 
结论 和 制定 决策 。 那 些 原 来 需要 外 包 的 工作 都 交 给 计算 机 算法 做 就 行 

了 ， 这 修 称 为 “< 厄 巴 纳 包 ”*。 工 作 人 员 如 末 不 能 让 雇主 相信 自己 提供 的 附 
加 价值 ， 就 会 失业 。 大 公司 继续 理直气壮 地 削减 薪资 。 不 少 公司 撤销 了 
设 在 海外 的 人 工 咨 询 台 服务 ， 代 之 以 计算 机 化 的 支持 多 种 语言 和 方言 的 
应 答 系 统 。 许 多 消费 者 在 民意 测验 中 表示 计算 机 提供 的 服务 比 被 取代 的 
人 工 服务 更 加 有 用 。 


有 些 国家 开始 立法 限制 厄 巴 纳 算法 的 应 用 以 保护 就 业 岗 位 ， 但 在 来 自 其 
他 国家 的 商业 竞争 压力 面前 ， 这 些 法 律 很 快 就 被 废止 了 。 和 情况 逐渐 有 了 
一 些 转 好 的 迹象 。 尼 巴 纳 算法 刺激 了 疲软 的 经 济 ， 催 生 了 新 兴 产 业 的 外 
形 。 大 学 里 开设 了 新 的 课程 ， 如 “ 厄 巴 纳 优 化 ”， 讲 授 拿 到 一 个 问题 后 如 
何以 最 快捷 简便 的 方式 运用 尼 巴 纳 算 法 解决 它 。 虽 然 长 远 来 看 ， 算 法 创 
造 的 就 业 机 将 会 远 远 多 于 失去 的 就 业 机 会 ， 但 还 是 有 许多 人 对 算法 耿耿 
于 怀 ， 蔡 那些 无 法 适应 新 经 济 体制 的 失业 者 哆 不 平 。 


政府 继续 推行 法 令 ， 保 护 民 众 不 受 厄 巴 纳 算法 的 冲击 ， 但 科技 的 影响 禾 
水 难 收 。 人 类 总 是 能 很 快 适应 新 形势 ， 渐 渐 很 少 有 人 会 在 民意 测验 中 表 





























示 愿 意 时 光 倒 流 ， 回 到 古老 的 2012 年 ， 逃 离 这 个 算法 和 带 来 的 美妙 世界 。 


2.8” 回 到 现实 


觉得 一 个 算法 能 改变 一 切实 在 令 人 难以 置信 ? 只 要 能 辨识 ， 就 能 找到 ? 
我 们 能 轻松 了 解 所 有 事物 ? 确实 不 太 可 能 ， 因 而 大 部 分 计算 机 科学 家 都 
认为 PzNP， 即 永远 不 会 发 现 尼 巴 纳 算法 或 是 类 似 的 算法 。 


无 论 P/NP 问 题 的 命运 如 何 ， 本 章 出 现 的 故事 中 有 一 部 分 还 是 可 能 会 变 成 
现实 的 。 但 那 将 是 一 场 持久 战 ， 我 们 必须 脚 蹄 实地， 逐个 攻破 技术 难 
关 ， 而 不 是 只 靠 神 奇 的 计算 机 代码 去 解决 所 有 的 问题 。 人 类 的 创造 力 是 
很 强大 的 ， 只 要 有 梦想 在 前 方 召唤 ， 我 们 最 终 一 定 能 设法 到 达 。 





第 3 章 P 和 NP 


3.1 政 友 国 


为 了 更 好 地 了 解 P 和 NP， 让 我 们 访问 一 个 假想 中 的 国度 一 一 收 友 国 。 在 
那里 ， 任 意 两 个 人 之 间 的 关系 不 是 朋友 ， 便 是 敌人 。 


收 友 国 住 痢 2 万 居民 。 单 看 每 个 人 者 很 正 币 ， 但 是 把 两 个 人 放 在 一 起 就 
会 发 生 奇 怪 的 事情 。 他 们 见 到 对 方 的 第 一 眼 ， 要 么 立刻 变 成 最 好 的 朋 

友 ， 要 么 马上 变 成 最 坏 的 敌人 。 虽 然 叫 敌 友 国 ， 但 从 没 看 到 过 两 个 人 的 
关系 会 有 中 间 立 场 ， 而 是 非 政 即 友 。 


看 上 去 敌 友 关系 几乎 是 随机 建立 的 。 朋 友 的 朋友 不 一 定 是 朋友 ， 也 可 能 
是 政 人 ， 天 人 的 敌人 亦 然 。 它 和 性 别 、 种 族 、 信 仰 和 社会 地 位 都 没什么 
关系 ， 不 过 人 们 更 倾 癌 于 树 政 而 不 是 交友 ， 大 部 分 人 的 朋友 数量 都 要 比 
敌人 少 很 多 。 


互联 网 提供 了 大 量 敌 友 国 中 朋友 关系 的 数据 。 通 过 检查 Facebook 和 
Twitter， 政 友 国 理工 学 院 的 计算 机 科学 家 们 获得 了 几乎 完整 的 数据 库 ， 
里 面 记录 了 哪 两 个 人 是 朋友 ， 哪 两 个 是 夏 人 。 在 本 章 ， 我 们 将 看 到 研究 
者 能 利用 这 些 数 据 做 什么 ， 不 能 做 什么 。 











3.2 ”六 上 度 理 论 


随便 从 政 友 国 挑 两 个 人 出 来 ， 不 妨 叫 他 俩 Alice 和 George， 两 个 人 互 为 朋 
友 的 可 能 性 很 低 。 但 他 们 可 能 有 一 个 共同 的 朋友 Bob， 也 可 能 没有 这 人 么 
一 个 人 。 收 友 国 理工 学 院 的 计算 机 科学 家 把 全 国 的 人 标记 在 一 张 散 点 几 
上 《每 个 点 代表 一 个 人 ) ， 并 在 代表 朋友 关系 的 两 点 之 间 连 一 条 线 。 这 
张 图 的 一 部 分 像 下 面 这 样 。 





Nh Eva 一 一 一 一 一 一 
Alice 
NA Cathy 
一 George 
Bob David 一 一 一 一 
/ Fred * 
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图 3-1 敌 友 国 的 好 友 关 系 图 


研究 者 发 现 要 连接 Alice 和 George， 中 间 要 经 过 6 个 人 : Alice 和 Bob 是 朋 
友 ，Bob 和 Cathy 是 朋友 ，Cathy 和 David 是 朋友 ，David 和 Eve 是 朋友 ， 
Eve 和 Fred 是 朋友 ，Fred 和 George 是 朋友 。 政 友 国 的 科学 家 想 ， 是 不 是 任 
章 两 个 人 都 能 通过 一 条 足够 短 的 好 友 链 联系 起 来 。 这 个 现象 称 为 “小 世 
界 ”， 不 是 得 名 于 迪士尼 乐园 里 那个 游乐 项 目 ， 而 是 因为 两 个 陌生 人 见 
面 ， 通 过 攀谈 发 现 彼 此 竟然 七 抛 八 弯 地 有 关联 时 ， 通 党 会 说 : “世界 真 
小 啊 ! ” 


1967 年 心理 学 家 斯 坦 利 : 米 尔格 拉 姆 做 了 一 个 著名 的 实验 来 检验 小 世界 














理论 。 他 首先 挑选 了 一 个 波士顿 地 区 的 股票 经 纪 人 ， 真 名 不 便 透 露 ， 我 
们 不 妨 叫 他 汤姆 :琼斯 。 米 尔格 拉 姆 随机 选择 了 100 个 来 自 内 布 拉 斯 加 州 
炒股 的 人 作为 第 一 组 ，100 个 不 炒股 的 人 作为 第 二 组 ， 妨 外 还 有 从 波 士 

顿 登 报 招 蕉 的 100 人 作为 第 三 组 。 来 目 内 布 拉 斯 加 州 的 第 二 组 人 和 波 士 

顿 第 三 组 的 人 跟 投 资 行 当 没 什么 特殊 的 联系 。 米 尔格 拉 姆 给 每 个 人 一 个 
装 有 实验 指令 的 档案 夹 、 一 本 人 花 名 册 ， 以 及 15 张 贴 了 邮票 能 寄 给 哈佛 大 
学 米尔 格拉 姆 的 明信片 。 实 验 指令 是 这 样 写 的 。 


1. 把 你 的 名 字 添 到 花 名 册 上 。 

2. 拿 一 张 明 信和 片 ， 把 它 塞 到 邮 简 里 寄 出 去 。 

3. 如 果 你 和 波士顿 的 股票 经 纪 人 汤姆 :琼斯 有 私交 ， 请 把 这 个 档案 夹 
寄 给 他 。 

4. 如 末 你 不 认识 汤姆 :琼斯 ， 把 档案 夹 寄 给 一 个 你 认识 的 人 人， 这 个 人 
的 名 字 没 有 出 现在 花 名 册 上 ， 而 且 你 觉得 他 更 有 可 能 认识 汤姆 : 琼 
斯 。 


300 个 人 中 总 共有 217 个 把 档案 寄 给 了 自己 的 朋友 ， 其 中 有 64 份 档案 最 终 
到 了 股票 经 纪 人 那里 。 好 友 链 的 平均 长 度 是 5.2 个 人 ， 从 而 产生 了 上 所谓 

六 度 分 割 的 概念 ， 就 是 说 任何 人 最 多 经 过 6 个 人 就 能 认识 所 有 人 。 尽 管 
许多 人 从 多 方面 指出 了 米尔 格拉 姆 研究 的 不 足 ， 并 且 他 本 人 从 没有 声称 
但 是 很 明显 ， 我 们 所 有 人 之 间 的 联系 比 预想 


如 果 要 用 某 种 比 仅 仅 听 说 过 某 人 更 为 明确 的 方式 来 定义 两 人 之 间 有 关 
联 ， 可 以 分 析 一 下 现实 中 的 人 际 网 络 。 这 启发 了 一 些 休 闲 时 玩 的 小 游 
戏 ， 基 本 玩法 是 看 看 某 人 与 一 个 特定 的 交际 很 广 的 人 的 距离 有 多 远 。 
1994 年 ， 演 员 凯 文 : 贝 肯 在 宣传 他 出 演 的 电影 《 狂 野 之 河 》 (The River 
Wild) 时 开 了 一 个 玩笑 ， 说 他 和 好 莱 坞 的 每 个 人 都 共事 过 ， 或 者 说 ， 他 
和 某 个 跟 每 个 人 都 共事 过 的 人 一 起 共事 过 。 于 是 大 家 开始 玩 “ 饥 文 : 贝 肯 
的 六 度 空 间 ” 这 个 小 游戏 ， 试 着 找 出 任意 一 个 演员 和 凯 文 : 贝 肯 之 间 联 系 
的 途径 ， 而 对 两 人 之 间 有 关联 的 定义 是 出 演 过 同一 部 片子 。 这 样 一 来 ， 
大 部 分 演员 和 凯 文 : 贝 表 的 关系 链 都 很 短 ， 所 以 其 实 他 们 彼此 之 间 也 很 
近 。 例 如 ， 从 查理 : 卓 别 林 到 凯 文 : 贝 肯 的 关系 链 长 度 为 3 捍 别 林 执 导 了 
1967 年 的 电影 《香港 女 伯 库 》 (A Countess from Hong Kong) 并 在 其 中 
扮演 了 一 个 小 角色 ， 女 伯 库 由 索菲亚 :罗兰 扮演 ， 索 菲 亚 : 罗 兰 主演 了 
1979 年 名 不 见 经 传 的 电影 《火力 》 (Firepower) ; 伊 莱 : 瓦 拉 赫 是 《 火 

















力 》 的 主要 演员 之 一 ， 在 《神秘 河 》 (Mystic River) 中 他 扮演 了 一 个 跑 
龙套 的 小 角色 ， 而 凯 文 : 贝 表 也 参 演 了 该 片 。 


数学 家 们 也 有 一 个 类 似 的 游戏 ， 通 过 “曾经 共同 撰写 一 篇 论文 ”这 种 关 
系 ， 看 看 茶 个 数学 家 离 发 表 车 作 很 多 的 组 合 数学 家 保罗 : 爱 多 士 有 多 
J 





1 我 和 三 个 与 保罗 . 爱 多 士 合 著 过 论文 的 人 一 起 写 过 论文 ， 所 以 我 的 “ 爱 多 士 分 数 ?" 是 2。 爱 多 士 于 
1996 年 辞世 ， 所 以 我 不 太 可 能 刷新 这 个 分 数 了 。 我 没有 演戏 的 经 历 〈 或 天 赋 ) ， 所 以 没有 “ 贝 肯 


分 数 "。 


敌 友 国 的 研究 者 决定 首先 检验 六 度 空间 法 则 在 他 们 的 国家 是 否 成 立 。 要 
检验 Alice 和 George 之 间 是 否 有 长 度 为 6 的 关系 链 ， 一 个 简单 的 方法 是 检 
查 所 有 长 度 为 6 的 关系 链 ， 看 看 其 中 是 否 有 一 条 以 Alice 和 George 为 端 
点 。 但 是 对 于 敌 友 国 的 2 万 居民 ， 所 有 长 度 为 6 的 关系 链 有 3 198 400 279 
980 000 480 000 种 可 能 ， 即 使 计算 机 每 秒 能 检查 1 万 亿 条 关系 链 ， 也 需 
要 100 多 年 才能 检查 完 。 有 没有 更 好 的 方法 来 检查 Alice 和 George 之 间 的 
距离 呢 ? 


有 。 可 以 用 几 个 简单 的 步骤 来 快速 找 出 Alice 和 George 之 间 的 距离 有 多 


大 


JI。 
































。 把 点 Alice 标 为 0。 

。 把 所 有 Alice 的 朋友 的 点 标 为 1。 

。 遍历 所 有 标记 为 1 的 点 ， 把 每 个 点 的 朋友 标 为 2 (除去 那些 已 经 标记 
人 

。 遍历 所 有 标记 为 2 的 点 ， 把 每 个 点 的 朋友 标 为 3 除去 那些 已 经 标记 
TI 

。 如 此 进行 ， 直 到 点 George 被 一 个 数字 标记 。 

。 点 George 上 标的 数字 就 是 Alice 和 George 之 间 的 距离 。 


像 这 样 对 计算 步骤 做 出 的 非 正 式 描述 束 叫 算法 (algorithm) ， 得 名 于 19 
世纪 波斯 数学 家 称 罕 默 德 . 伊 本 . 称 陕 . 花 刺 子 密 。 公 元 825 年 ， 花 刺 子 密 
发 表 了 《 论 印 度数 字 的 计算 》 (On the Calculation with Hindu 
Numerals) ， 这 本 著作 的 意义 是 将 印度 的 计数 系统 推广 到 中 东 和 欧洲 。 
书 名 的 拉丁 文 译 法 是 Algoritmi de numero Jndorum，Al-KhwarizmIi ( 花 刺 
子 密 ) 在 拉丁 语 里 变 成 了 Algoritmi， 然 后 变 成 了 今天 的 术语 algorithm。 





上 述 算法 能 用 差不多 50 万 步 计 算出 Alice 和 George 的 距离 。 要 找到 所 有 政 
友 国 居民 中 任意 一 对 之 间隔 了 多 远 ， 我 们 需要 更 高 明 的 算法 。Floyd- 
Warshall 算 法 能 用 大 概 8 万 亿 步 就 计算 出 所 有 这 些 距离 。 可 能 你 觉得 1 万 
亿 这 个 数 听 起 来 插 大 ， 但 如 今 的 个 人 计算 机 每 秒 都 能 执行 几 十 亿 个 操 
作 。 敌 友 国 理工 学 院 的 机 器 在 几 分 钟 内 就 计算 出 了 全 部 国民 之 间 的 分 隔 
距离 。 科 学 家 们 发 现 本 国 的 平均 分 隔 距离 比 6 要 稍 大 一 点 ， 尽 管 有 些 人 
组 成 的 朋友 圈 非 常 孤立 ， 里 面 的 人 和 圈 外 的 人 都 不 是 朋友 。 


我 们 可 不 能 低估 刚才 发 生 的 事情 的 意义 。 当 然 研究 者 可 以 编程 过 历 所 有 
路 径 ， 找 出 其 中 连接 Alice 和 George 且 最 短 的 一 条 ， 但 这 样 做 可 能 要 检查 
的 路 径 太 多 了 ， 导 致 程序 没 法 在 合理 时 限 内 跑 完 。 然 而 采用 某 种 更 简单 
的 算法 ， 他 们 能 在 一 秒 内 算出 Alice 和 George 之 间 的 距离 ， 并 且 在 儿 分 钟 
内 算出 敌 友 国 居 民 中 任意 一 对 之 间 的 距离 。 























3.3” 罕 线 搭桥 


在 敌 友 国 ， 一 段 美 满 的 姻缘 几乎 完全 取决 于 双方 是 否 是 很 好 的 朋友 。 然 
而 敌 友 关系 的 分 布 完全 没有 规律 ， 有 些 注 运 儿 可 能 磁 巧 找到 了 合适 的 人 
选 ， 剩 下 的 人 则 很 难 找到 一 个 好 伴侣 。 


敌 友 国 的 研究 者 意识 到 可 以 用 他 们 的 数据 来 为 社会 服务 ， 让 成 功 婚姻 的 
数量 最 大 化 。 于 是 他 们 在 网 站 上 招 竹 了 200 个 志愿 者 ， 其 中 一 半 是 男 
性 ， 一 半 是 女性 ， 所 有 人 都 是 异性 恋 。 他 们 想 尽 可 能 多 地 为 合适 的 男女 
牵线 搭桥 。 


一 共 需 要 搜索 多 少 种 可 能 性 呢 ? 和 第 一 个 男性 配对 的 女性 人 选 有 100 个 
可 能 。 做 出 选择 后 剩 下 的 99 个 女性 可 能 和 第 二 个 男性 配对 ， 然 后 是 98 个 
女性 和 第 三 个 男性 配对 ， 如 此 等 等 。 这 样 所 有 的 可 能 数 是 100 乘 以 99 乘 
以 98 乘 以 ……… 乘 以 2 乘 以 1， 这 个 值 被 称 为 "100 的 阶乘 >， 写作 100!， 这 
个 数 有 158 位 ， 比 googol 还 大 。googol 这 个 名 字 是 数学 家 爱德华 : 卡 斯 纳 
九 岁 的 侄子 起 的 ， 当 时 卡 斯 纳 想 给 1 后 边 跟 100 个 0 的 数 起 名 。 


互联 网 公司 Google 得 名 于 对 googol 的 错误 拼写 ， 它 是 对 该 公司 搜索 引擎 
所 处 理 的 海量 数据 的 一 个 形象 但 非常 不 准确 的 表示 。 互 联网 这 种 庞 然 大 
物 《〈 实 际 上 无 法 测量 它 有 多 大 ) 所 包含 的 信息 量 无 论 分 得 多 细 ， 都 还 远 
远 达 不 到 googol 这 个 数量 级 。 所 以 ， 即 使 动用 全 部 的 计算 机 算 到 地 老 天 
荒 ， 也 不 可 能 搜索 googol 数 量 级 的 信息 ， 更 别提 100! 了 。 


然而 敌 友 国 研究 者 还 是 能 找到 成 功 配 对 数 的 最 大 可 能 值 ， 只 需 换 一 个 高 
明 的 算法 即 可 。 下 边 这 张 图 显示 了 哪些 男女 志愿 者 是 朋友 关系 。 











Arthur Eve 
Bob Felicity 
Carl Gail 

David Helen 


图 3-2 敌 友 国 的 男女 们 


让 我 们 看 看 谁 跟 谁 可 能 是 天 作 之 合 。 首 先 我 们 把 Arthur 和 Eve 凑 成 一 
对 。Bob 和 Felicity 这 对 朋友 还 没有 在 一 起 ， 让 我 们 促成 他 俩 ， 同 样 祝 福 
Carl 和 Gail。 现 在 我 们 有 了 一 张 新 图 ， 虚 线 表示 我 们 做 出 的 配对 选择 。 
Arthur 
Bob Felicity 


Carl Gail 





David Helen 


图 3-3 ”部 分 配对 的 男女 们 
这 下 不 存在 能 够 配对 的 朋友 了 ， 这 是 可 能 的 配对 结果 中 最 好 的 吗 ? 不 一 
定 ; 


David 没 有 伴侣 ， 但 他 和 Felicity 是 朋友 ， 而 Felicity 和 Bob 在 一 起 。Bob 和 
Gail 是 朋友 “但 我 们 没有 撮合 他 俩 ) 。Gail 和 Carl 是 一 对 。Carl 和 没有 伴 
儿 的 Helen 是 朋友 。 如 果 我 们 拆散 Bob 和 Feliciy， 再 坏 了 Carl 和 Gail 的 好 
事 ， 然 后 重新 配对 ， 那 么 这 下 所 有 人 都 成 功 配对 了 。 

















Arthur 

Bob 一 -一 

Carl RE 一 SR Gail 
Bl Helen 


图 3-4 全 部 配对 的 男女 们 


第 二 张 图 中 连接 两 个 人 的 实 线 和 虚线 的 序列 ， 叫 做 增 广 路 径 
(augmenting path)， 它 可 以 用 来 增 大 配对 的 数量 。1957 年 ， 克 劳 德 - 伯 
杰 证 明 任何 未 达到 最 大 可 能 配对 数 的 匹配 方式 都 对 应 一 个 增 广 路 径 。 政 
友 国 理工 学 院 的 计算 机 科学 家 写 了 一 个 简单 的 算法 来 找到 这 些 增 广 路 
径 ， 结 果 让 参加 实验 的 98% 的 人 都 成 功 配对 。 


不 久 以 后 ， 收 友 国 最 高 法 院 裁定 ， 允 许 同性 结婚 。 于 是 学 院 在 网 站 上 张 
贴 启事 ， 招 对 所 有 性 别 取 回 的 志愿 者 。 这 下 关系 图 更 复 汪 了， 出 现 了 许 
多 彼此 交合 的 三 角 恋 爱 关 系 ， 如 下 所 示 。 


John 一 一 Larry 
Karen a Mark 
Nancy 


图 3-5 ”打破 传统 的 男男女女 


这 导致 寻找 增 广 路 径 的 简单 算法 不 好 用 了 。 人 研究 者 转 而 求助 于 杰 元 : 埃 
德 蒙 兹 的 工作 。 在 1965 年 ， 埃 德 蒙 北 写 了 一 篇 标题 很 文艺 的 论文 “路 

径 、 树 木 与 花 杂 ”(Path, Trees and Flowers) ， 里 面 介绍 了 一 种 稍为 复杂 
的 方法 ， 能 够 在 广义 好 友 关 系 图 中 找 出 增 广 路 径 。 敌 友 国 理工 学 院 采 用 
埃 德 蒙 效 的 思路 ， 从 而 能 够 让 97% 的 参与 第 二 个 实验 的 人 找到 合适 的 伴 


侣 。 


“路 径 、 树 木 与 花 示 ”中 的 思想 ， 除 了 能 为 解决 广义 好 友 关 系 图 中 的 配对 
问题 提供 一 种 有 效 的 方法 ， 还 有 更 大 的 影响 。 埃 德 绽 兹 的 算法 为 100 个 
人 找到 最 佳 匹 配 需要 大 概 100“ 个 计算 步骤 。 对 于 今天 的 计算 机 ， 计 算 
100〈 即 1 亿 ) 次 一 点 也 不 费劲 ， 而 更 原始 的 穷 举 方法 大 概 需要 的 计算 
步骤 数 是 2 后 边 跟 78 个 0。 欣 德 蒙 效 在 论文 里 还 写 了 很 多 题 外 话 ， 探 讨 高 
效 算法 的 本 质 。 他 意识 到 不 存在 能 够 完全 抓 住 “效率 ”直观 概念 的 严格 定 
义 ， 于 是 他 试 着 提出 自己 对 高 效 的 见解 ， 即 存在 一 个 计算 方法 ， 它 解决 
这 种 规模 的 问题 所 花费 的 时 间 是 “算术 级 别 的 "， 比如 1004、100 人 或 
100“。 后 来 这 一 类 型 的 问题 有 了 另 一 个 人 们 更 为 熟知 的 名 字 一 一 P《〈 代 
表 polynomial， 多 项 式 级 别 的 ， 它 代 丛 了 埃 德 蒙 效 的 “算数 级 别 的 ”) ， 
人 们 用 它 来 指 代 那 些 可 以 高 效 解 决 的 问题 。 这 就 是 P/NP 问 题 中 P 的 一 
面 。 














3.4 问题 


敌 友 国 理工 学 院 的 一 个 社会 学 教授 想 做 一 个 实验 ， 为 此 需要 找到 彼此 互 
为 朋友 的 50 个 居民 。 她 自己 办 不 到 ， 就 回 儿 个 计算 机 科学 家 请 教 这 个 问 
题 ， 他 们 说 手 尖 刚好 有 哪些 人 是 朋友 的 数据 。“ 找 50 个 互 为 朋友 的 人 组 
成 的 团 是 吧 ， 应 该 没 问 题 。” 一 个 计算 机 科学 教授 说 。 


但 是 有 问题 ， 而 且 是 个 很 难 的 问题 。 从 敌 友 国 里 挑 出 50 个 人 的 不 同方 案 
的 个 数 ， 是 一 个 151 位 的 天 文 数字 ， 根 本 不 可 能 逐个 检查 。 研 究 者 们 为 
此 想 尽 了 办 法 ， 比 如 他 们 意识 到 ， 如 果 一 个 人 拥有 朋友 的 数量 不 到 50 

个 ， 那 么 这 个 人 不 可 能 在 一 个 50 人 的 团 里 。 即 便 如 此 ， 他 们 绞 尽 脑汁 ， 
却 连 25 个 互 为 朋友 的 人 都 找 不 出 来 ， 而 且 也 不 能 有 效 证 明 整 个 敌 友 国 不 
存在 50 人 的 团 。 


束 在 他 们 想 放 莽 的 时 候 ， 有 一 个 研究 生 说 ;“ 人 不 是 有 个 阿尔 法 会 吗 ?”” 阿 
尔 法 会 《Alpha Society) 是 一 个 富有 传奇 色彩 的 、 半 地 下 社会 组 织 ， 据 
说 里 边 人 人 都 是 朋友 。 计 算 机 科学 家 设法 找到 了 50 个 阿尔 法 会 会 员 的 名 
字 (幸好 这 个 组 织 只 是 “ 半 地 下 ”) 。 有 了 这 50 人 的 名 单 ， 就 只 要 检验 

1225 对 人 是 不 是 朋友 就 可 以 了 。 结 果 他 们 真 的 每 两 个 人 都 是 朋友 ， 这 让 
计算 机 科学 家 们 惊讶 不 已 ， 而 阿尔 法 会 会 员 们 表示 淡定 。50 个 互 为 友人 
组 成 的 团 就 这 样 被 找到 了 。 








3.5 “ 递 棍 儿 ?” 


让 我 们 看 看 一 个 求解 简单 的 问题 ， 怎 样 经 过 一 点 小 小 的 改动 ， 就 变 成 一 
个 非常 难 求解 的 问题 。 


敌 友 国 的 小 孩子 们 玩 一 种 叫 “ 递 棍 儿 ”的 游戏 。 他 们 把 一 个 小 棍子 传 来 传 
去 。“ 第 ”的 意思 是 在 把 棍子 从 一 个 孩子 传 到 为 一 个 时 ， 两 个 人 一 起 把 它 
握 住 。 

规则 有 两 条 : 


1. 只 能 给 你 的 朋友 递 棍 儿 ; 
2. 每 对 朋友 之 间 必 须 递 一 次 棍子 ， 且 只 能 递 一 次 。 


假设 5 个 小 孩 在 玩 这 个 游戏 。 


从 Barbara 开 始 ， 她 把 棍子 递 给 Eric，Eric 递 给 Alex， 然 后 棍子 依次 经 过 
Cathy、Eric， 最 终 被 递 给 David， 游 戏 成 功 结束 。 











Alex 
David 


Barbara 


Eric 


Cathy i 


图 3-6 ”孩子 们 


玩 了 几 次 孩子 们 很 快 发 现 游戏 能 成 功 结束 的 前 提 是 ， 拥 有 朋友 个 数 为 奇 
数 的 人 不 能 超过 两 个 : 如 David 和 Barbara 分 别 有 1 个 朋友 ， 是 奇数 ， 而 
Cathy 和 Alex 分 别 有 2 个 和 4 个 朋友 ， 是 偶数 。 为 什么 昵 ? 因为 除了 第 一 
个 和 最 后 一 个 人 ， 其 他 人 接 棍子 的 次 数 和 把 棍子 递 给 朋友 的 次 数 必 须 相 


等 ， 所 以 这 些 人 中 间 的 每 个 人 经 手 棍子 的 次 数 应 该 是 偶数 。 


如 果 每 个 孩子 都 有 偶数 个 朋友 ， 那 么 游戏 也 能 玩 成 ， 只 要 保证 开始 和 结 
束 时 是 同一 个 人 就 可 以 了 。 


比如 孩子 们 可 以 这 样 传 棍 子 : 从 Alex 开 始 ， 棍 子 依次 经 过 Eric、David、 
Barbara、Eric、Cathy， 最 终 回 到 Alex 手 上 。 


Alex 
David 


Barbara 


Eric 
Cathy 


图 3-7 ”每 个 孩子 都 有 偶数 个 朋友 


“ 递 棍 儿 ”的 灵感 来 自 19 世 纪 的 一 个 善 名 难题 。 在 普鲁士 的 哥 尼 斯 堡 ( 今 
俄罗斯 加 里 宁 格 勒 》 有 七 座 桥 模 跨 于 普 雷 格 尔 河 上 ， 请 看 这 张 老 地 图 。 





图 3-8” 柯 尼斯 堡 的 桥 


哥 尼 斯 堡 的 市 民 想 知道 能 人 否 有 一 条 路 线 跨 过 每 座 桥 一 次 ， 并 且 只 路 过 一 
次 。1735 年 ， 著 名 的 数学 家 沫 帅 哈 德 : 欧 拉 着 手 解决 这 个 问题 ， 他 男 了 
一 张 图 。 


和 * 递 棍 儿 ?游戏 中 的 孩子 们 不 同 的 是 ， 北 区 和 岛 区 、 怠 区 和 南 区 之 间 都 
有 多 重 的 “友谊 ”， 即 桥梁 。 然 而 原理 是 一 样 的 ， 欧 拉 证 明 ， 没 有 人 能 将 
每 座 桥 跨 过 并 且 只 跨 过 一 次 ， 因 为 四 块 地 区 都 有 奇数 条 桥梁 与 其 他 地 区 
相连 











北 区 . 


误区 一 一 一 一 不 区 


南 区 
图 3-9 欧 拉 的 难题 


因为 源 于 欧 拉 和 哥 尼 斯 堡 七 桥 难题 ,“ 弟 棍 儿 ”游戏 的 成 功 完 成 方式 叫做 
欧 拉 回路 。 玩 的 人 比较 多 时 ， 完 成 游戏 的 方式 可 能 有 很 多 种 ， 但 孩子 们 
可 以 很 容易 地 判断 能 不 能 玩 成 ， 只 要 数 数 有 几 个 人 的 朋友 个 数 是 奇数 就 
行 了 。 


随 着 政 友 国 的 孩子 们 渐渐 长 大 ， 他 们 觉得 “ 递 棍 儿 ” 太 简 单 了 ， 没 劲 。 于 
征 他 们 稍微 改 了 一 下 规则 ， 新 游戏 起 名 为 “ 递 杭 儿 2 (页 没 创 意 ) 。 修 
改 后 的 规则 如 下 : 


1. 只 能 给 你 的 朋友 递 棍 儿 ; 
2. 棍子 必须 上 且 只 能 每 个 人 经 手 一 次 ， 第 一 个 递 出 棍子 的 人 除外 ， 因 为 
棍子 最 终 要 还 到 他 手 里 。 











以 下 边 这 张 朋 友 关 系 图 为 例 ，David 把 棍子 递 给 Barbara， 然 后 棍子 依次 
经 过 Eric、Alex、Cathy， 最 终 递 回 David 手 上 。 


Alex 
David 


Barbara 


Eric 


\ 


Cathy 


图 3-10 ”可 以 完成 的 “ 北 棍 儿 ” 
而 在 接 下 来 这 张 图 里 ， 孩 子 们 发 现 不 可 能 完成 “ 递 楷 儿 2”。 
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图 3-11 不 可 能 完成 的 “ 递 棍 儿 ” 


由 于 规则 变 简 单 了 ， 孩 子 们 以 为 “ 递 棍 儿 2? 会 更 容易 解决 。 但 是 当 人 数 

变 得 较 多 时 ,“ 递 棍 儿 2 的 难度 陡然 上 升 。1857 年 ， 数 学 家 威廉 : 罗 因 . 哈 
密 顿 发 明了 一 个 叫 Icosian 的 数学 游戏 。 我 们 可 以 用 "“ 递 棍 儿 2? 来 描述 它 

的 玩法 ， 为 了 让 图 更 简单 ， 我 们 把 每 个 人 用 名 字 的 首 字母 代 丛 。 





图 3-12 ”Icosian 难 题 


Icosian 游 戏 来 自 正 十 二 面体 ， 即 一 个 有 十 二 个 平面 的 球 。 





图 3-13 十 三 面体 
如 果 顶 点 代表 政 友 国 的 人 ， 每 条 边 代 表 一 对 朋友 之 间 的 关系 ， 就 会 得 到 





上 面 那 张 好 友 关 系 图 。 


为 了 纪念 Icosian 游 戏 的 发 明 者 ,“ 递 棍 儿 2” 游 戏 的 成 功 完成 方式 叫做 哈 
密 顿 回路 。 





3.6” 刷 房子 


政 友 国 政府 颁布 了 一 个 新 法 案 ， 要 求 所 有 公民 为 了 城市 的 类 观 ， 必 须 把 
自家 的 房子 刷 成 和 所 有 邻居 的 房子 不 一 样 的 颜色 ， 无 论 邻 里 之 间 是 敌 是 
友 。 很 多 人 表示 抗议 ， 说 这 是 强制 让 民众 日 花 钱 、 做 盏 工 。 后 来 政府 同 
意 用 公共 资金 为 居民 刷 房 报销 全 款 ， 但 有 一 个 条 件 : 刷 什 么 颜色 要 由 政 
奉 来 定 。 


由 于 要 买 的 涂料 数量 巨大 ， 政 府 职能 机 构想 尽 可 能 减少 购买 的 涂料 颜色 
的 种 类 。 少 用 一 种 颜色 就 能 省 下 几 百 万 美元 。 政 府 给 敌 友 国 理工 学 院 拨 
了 一 笔 钱 ， 让 他 们 找到 最 少 需要 几 种 颜色 的 涂料 才能 保证 所 有 相 邻 的 房 
子 都 有 不 同 的 颜色 。 


政 友 国 每 家 最 多 有 12 个 邻 后 。 所 以 最 容易 想到 和 实现 的 方案 需要 13 种 颜 
色 : 每 个 邻居 刷 一 种 不 同 的 颜色 ， 然 后 中 间 的 房子 刷 第 13 种 颜色 。 但 政 
友 国 的 研究 者 觉得 他 们 还 能 做 得 更 好 。 


1852 年 ， 南 非 数学 家 弗朗西斯 : 格 思 里 在 为 英国 各 郡 的 地 图 填 色 时 ， 猜 
想 是 否 只 用 四 种 颜色 ， 就 足够 让 所 有 地 图 上 每 两 个 接壤 的 地 区 有 不 同 的 
颜色 。 当 时 很 多 数学 家 都 考虑 了 格 思 里 提出 的 问题 ， 接 着 在 1879 年 和 

1880 年 出 现 了 两 个 四 色 问 题 的 “证 明 ”， 分 别 由 阿尔 弗 雷 德 ' 肯 普 以 及 彼 

得 . 泰 特 发 表 。11 年 后 两 个 证 明 都 被 发 现 有 致命 错误 ， 在 之 后 几乎 一 个 
世纪 的 时 间 ， 这 个 问题 都 未 能 得 到 解决 。 


1976 年 ， 肯 尼斯 ' 阿 假 尔 和 沃 尔 夫 冈 : 哈 上 衣 终 于 给 出 了 四 色 问 题 的 证 明 ， 

但 他 们 使 用 了 一 种 非常 有 争议 的 技术 。 证 明 过 程 需要 用 一 个 计算 机 穷 举 
所 有 可 能 的 情况 来 支持 他 们 的 论点 。 传 统 数学 家 不 相信 这 样 的 证 明 ， 因 
为 它 不 能 完全 用 人 的 思维 来 检验 。 但 是 几 十 年 过 去 了 ， 人 们 没有 找到 阿 
佩 尔 - 哈 肯 证 明 中 有 任何 错误 ， 如 今 大 多 数 人 都 相信 ， 四 种 颜色 足够 为 
所 有 的 地 图 填 色 。 


四 就 是 极限 了 吗 ? 三 种 颜色 够 不 够 填 满 所 有 地 图 ? 不 够 ， 来 看 内 华 达 州 
和 筷 接 壤 的 州 。 























爱 达 荷 州 







加 利 福 尼 亚 州 


亚 利 双 那州 


图 3-14 内 华 达 州 


加 利 福 尼 亚 州 、 俄 勒 闪 州 、 爱 达 蓓 州 、 犹 他 州 和 亚利桑那 州 ， 这 几 个 州 
在 内 华 达州 外 面 围 成 一 轿 。 由 于 这 个 圈 包 含 奇 数 个 州 〈《5 个 ) ， 需 要 至 
少 三 种 颜色 来 填充 它们 ， 如 果 只 有 两 种 颜色 ， 比 如 绿 和 卜 ， 加 利 福 尼 亚 
州 涂 绿色 ， 与 之 接壤 的 俄 勒 崔 州 必然 是 赣 色 ， 然 后 爱 达 荷 州 必须 是 绿 

色 ， 犹 他 州 是 蓝 色 。 现 在 ， 亚 利 又 那州 分 别 与 绿色 的 加 利 福 尼 亚 州 和 蓝 
色 的 犹他 州 接 壤 ， 所 以 它 既 不 可 以 是 绿色 ， 也 不 能 是 赣 色 。 上 所 以 我 们 至 
少 需要 三 种 颜色 一 一 蓝 、 绿 和 黄 ， 来 填充 这 五 个 州 。 


内 华 达 州 与 五 州 分 别 接壤 ， 那 么 它 不 能 填 蓝 、 绿 或 黄 这 三 种 颜色 。 所 以 
我 们 需要 第 四 种 颜色 一 一 红 ， 来 为 内 华 达 州 上 色 。 


有 了 基于 四 色 定 理 的 证 明 的 高 效 算 法 ， 就 可 以 很 快 为 任意 地 图 涂 上 四 种 
颜色 。 于 是 敌 友 国 的 研究 者 找到 了 用 四 种 颜色 给 所 有 房子 刷 漆 的 方法 ， 
保证 了 相 邻 房子 的 颜色 不 同 。 政 府 又 敦促 学 院 找 到 只 用 三 种 颜色 涂料 的 
方法 。 恰 巧 敌 友 国 没有 邻居 个 数 为 奇数 的 房子 ， 所 以 研究 者 没 办 法 直接 
排除 只 用 三 种 颜色 的 方法 存在 的 可 能 性 。 


计算 机 科学 家 们 几经 尝试 ， 最 终 放 弃 了 。 他 们 向 政府 报告 找 不 到 只 用 三 


种 颜色 的 涂 色 方案 。 政 府 不 得 不 使 用 四 种 颜色 的 方案 粉刷 所 有 房子 。 政 
友 国 的 计算 机 科学 家 们 将 来 在 申请 政府 津贴 时 会 遇 到 更 多 困难 。 


3.7” 人 组 
敢 友 国 小 学 的 老师 想 把 500 个 学 生 分 成 两 组 。 每 个 人 都 想 和 朋友 在 一 


起 ， 所 以 老师 想 尽 可 能 避免 把 一 对 好 友 分 到 两 个 组 去 。 让 我 们 用 "“ 递 棍 
儿 ” 游 戏 中 的 那 张 好 友 关 系 图 来 看 看 。 
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图 3-15 ”小 学 


最 好 的 分 组 方法 是 把 Alex 和 Cathy 放 在 一 组 ，Barbara、David 和 Eric 在 男 
一 组 ， 这 样 只 拆散 了 两 对 好 友 ，Alex 一 Eric 以 及 Cathy 一 Eric。 不 存在 只 
拆散 一 对 好 友 的 方案 。 


Alex 


\ 
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图 3-16 ”小 学 的 分 组 





敌 友 国 小 学 的 校长 向 学 院 求助 。 有 很 多 有 效 的 方法 可 以 解决 这 个 问题 ， 
它 被 称 为 最 小 制 问题 ， 因 为 老师 想 把 被 分 割 的 好 友 数 减 到 最 小 。 研 究 者 
针对 这 500 个 学 生 给 出 了 一 个 很 好 的 分 组 方案 ， 只 拆散 了 17 对 好 友 。 


从 此 以 后 所 有 人 都 过 上 了 快乐 的 生活 。 说 “从 此 以 后 ?不 太 准 确 ， 事 实 上 
只 过 了 一 天 ， 老 师 就 发 现 ， 把 很 多 互 为 仇 政 的 小 孩 分 到 一 组 太 粳 糕 了 ， 
比 拆散 好 友 更 不 可 取 。 于 是 校长 回 到 学 院 ， 请 研究 者 找到 一 种 把 尽 可 能 
多 的 互 为 敌人 的 学 生 分 到 不 同 组 里 的 方案 。 校 长 觉得 第 一 次 的 分 组 问题 
解决 得 那么 轻松 ， 这 次 应 该 也 不 会 太 难 。 校 长 想 错 了 。 


在 这 个 新 问题 里 ， 研 究 者 需要 尽 可 能 多 地 把 政和 人 分割 开 ， 这 叫做 最 大 制 
问题 。 但 是 不 像 最 小 割 问题 ， 计 算 机 科学 家 不 知道 哪 种 算法 能 最 大 化 被 
分 割 到 两 个 组 的 仇敌 数目 。 


也 不 是 完全 无 计 可 施 。 学 院 利 用 1995 年 由 米 鞭 尔 : 戈 老 斯 和 大 卫 : 威 廉 森 
写 的 算法 ， 找 到 了 一 个 将 1321 对 政和 分割 到 两 个 组 的 方案 。 尺 管 没 能 找 
出 最 好 的 方案 ， 但 他 们 知道 不 存在 把 1505 对 及 以 上 的 政 人 分 割 到 两 组 的 
方案 。 校 长 有 反 失 望 ， 他 以 为 学 院 能 找到 最 好 的 方 采 ， 但 现 有 方案 也 还 
算 合理 。 从 此 以 后 所 有 人 都 过 上 了 更 加 快乐 或 更 加 郁闷 的 生活 。 























3.8 P 和 NP 


让 我 们 看 看 哪些 问题 让 歼 友 国 的 研究 者 们 头疼 不 已 :， 团 、 哈 密 顿 回路 
(“ 递 棍 儿 2”) 、 地 图 填 色 ， 以 及 最 大 割 。 这 些 问 题 有 一 个 共性 ， 都 可 
以 用 很 简单 的 方法 检查 方案 的 有 效 性 。 一 旦 敌 友 国 的 科学 家 找到 了 阿尔 
法 会 的 成 员 ， 台 很 容易 验证 古人 不 是 所 有 成 员 之 间 都 互 为 朋友 ， 即 阿尔 法 
会 成 员 组 成 的 是 一 个 团 。 孩 子 们 如 果 听 说 了 一 个 能 完成 “ 递 棍 儿 ”游戏 的 
方法 ， 只 要 顺 着 方法 玩 一 裔 就 知道 对 不 对 。 随 便 给 出 一 个 涂 色 方 案 ， 政 
府 很 容易 检查 它 是 否 符合 相 邻 的 房子 颜色 不 同 。 在 最 后 一 个 例子 里 ， 对 
于 任意 一 个 分 组 方式 ， 校 长 只 要 数 数 有 几 对 敌人 被 分 开 束 能 判断 方案 的 
好 坏 。 


这 一 类 能 够 很 快 验证 一 个 解 的 有 效 性 的 问题 ， 计 算 机 科学 家 给 它们 起 了 
一 个 名 字 : NP。 如 果 你 非 想 知道 的 话 ， 这 两 个 字母 代表 nondeterministic 
polynomial time 〈 不 确定 性 多 项 式 时 间 ) 。 团 、 哈 密 顿 回路 、 地 图 填 色 
和 最 大 割 都 是 NP 中 的 典型 例子 。 


与 之 形成 对 比 的 是 P 类 问题 ， 即 我 们 能 很 快 找到 最 优 解 的 这 些 问 题 : 最 
短路 径 、 配 对 、 欧 拉 回 路 “〈“ 递 棍 儿 1 ) ， 以 及 最 小 割 。 


也 许 存在 能 快速 找到 团 的 高 明 算 法 。 可 能 将 来 某 个 聪明 的 研究 生 能 想 出 
如 何 轻 松 找 出 哈密 顿 回路 ， 或 是 一 个 最 大 化 分 割 敌 人 到 两 个 小 组 的 快速 
步骤 。 也 许 团 、 哈 密 顿 回路 、 地 图 填 色 和 最 大 割 也 是 在 P 类 问题 中 的 ， 

就 像 最 短路 径 、 配 对 、 欧 拉 回 路 和 最 小 割 一 样 。 也 许 NP 中 的 每 个 问题 
都 有 一 个 快速 的 解法 ， 我 们 只 是 不 知道 而 已 。 


这 就 是 P/NP 问 题 。P=NP 意 味 着 美好 世界 的 到 来 ， 每 个 NP 中 的 问题 都 对 
应 一 个 有 效 的 解法 ， 也 就 是 说 每 个 有 解 的 问题 都 能 很 快 地 验证 给 定 解 ， 
并 且 快 速 地 找到 其 中 最 优 的 解 。 与 此 相反 ， 如 果 哪 怕 有 一 个 NP 中 的 问 
题 我 们 找 不 到 能 给 出 快速 解法 的 算法 ， 那 么 P 还 是 不 等 于 NP。 


判断 P 是 否 等 于 NP 是 计算 机 科学 乃至 整个 数学 领域 最 关键 的 问题 。 许 多 
人 呕心沥血 ， 试 图 找到 解决 团 、 哈 密 顿 回路 或 其 他 问题 的 好 算法 ， 可 惜 
都 失败 了 。 与 此 相反 ， 要 证 明 PzNP， 必 须 证 明 无 论 现 在 还 是 将 来 ， 都 
不 可 能 存在 能 够 快速 找到 团 或 解决 其 他 NP 问 题 的 算法 。 如 何 证 明 一 件 






































事 不 可 能 做 成 ? 目前 这 两 个 研究 方 同 部 没有 什么 实质 性 进展 。 


正 古 认识 到 了 P/NP 问 题 的 重要 性 ， 克 雷 数学 研究 所 才 决 定 为 解决 它 的 人 
提供 一 百 万 美元 的 奖金 。 也 正 因为 它 无 比 关 键 ， 才 促使 我 写 出 了 这 本 
书 。 





3.9 敌 友 国之 外 


这 章 给 出 的 只 是 几 个 例子 ， 除 此 之 外 还 有 成 千 上 万 个 我 们 不 能 快速 求解 
的 NP 问题 。 要 是 你 觉得 除了 计算 机 科学 家 和 子虚乌有 的 敌 友 国 居民 之 
外 ， 没 有 人 会 对 P/NP 问 题 感 兴 趣 ， 那 么 请 让 我 列举 一 小 部 分 来 自 其 他 学 
科 领 域 的 例子 ， 我 们 同样 不 知道 下 面 这 些 问题 的 有 效 算法 。 


1. 生物 学 


人 类 有 23 对 染色 体 。 每 条 染色 体 上 都 排 布 着 由 碱 基 对 组 成 的 基因 序列 ， 
碱 基 对 有 四 种 ， 即 腺 嘎 叭 (A，adenine) 、 胞 喀 啶 〈C，cytosine) 、 乌 
味 叭 〈G，guanine) 和 胸腺 喀 啶 〈T，thymine) 。 染 色 体 序列 可 能 以 
ACTGATTACA 开 始 ， 可 能 会 很 长 。 最 短 的 序列 有 4700 万 碱 基 对 ， 最 长 
的 有 2 亿 4700 万 碱 基 对 。 当 代 DNA 测 序 技术 一 次 只 能 测定 大 约 20 一 1000 
个 碱 基 对 。 生 物 学 家 需要 想 办 法 把 许多 短小 的 序列 片段 拼接 成 完整 的 序 
列 。 拼 接 序 列 是 一 个 很 难 的 计算 问题 ， 也 是 一 个 NP 问题 ， 因 为 如 果 我 
们 提前 知道 了 要 拼接 的 DNA 序 列 的 全 貌 ， 我 们 可 以 用 相对 较 快 的 方式 检 
查 某 种 拼接 方式 是 否 与 之 匹配 。 由 于 找 不 到 解决 这 个 NP 问题 的 有 效 得 
法 ， 生 物 学 家 需要 更 多 的 序列 才能 绘制 出 基因 组 图 谱 。 而 且 很 可 能 绘制 
出 的 图 谱 上 有 更 多 的 空白 和 错误 。 研 发 出 藤 接 序列 的 最 优 算法 将 显著 提 
升 基因 图 谱 的 质量 。 


DNA 序 列 能 编码 信使 RNA (mRNA) 的 序列 ， 后 者 负责 蛋白 质 的 表达 ， 
而 乍 白 质 则 在 组 成 生物 细胞 的 几乎 所 有 功能 中 发挥 着 关键 性 作用 。 借 白 
质 执行 何 种 功能 遂 营 依赖 于 特定 的 几何 形状 ， 而 mRNA 序 列 决定 集 日 质 
如 何 折合 ， 从 而 具有 这 种 形状 。 和 集 白 质 折 登 的 计算 过 程 仍然 是 生物 学 一 
大 未 解 之 恋 ， 研 究 P/NP 问 题 对 理解 集 白 质 折合 有 关 重 要 的 局 改作 用 ， 进 
而 帮助 人 类 预防 和 抵抗 疾病 。 


和 掉 白质 折 铬 识别 (protein threading) 是 一 种 根据 mRNA 序列 来 预测 和 蛋白 
质 折 车 方式 的 统计 学 方法 。 即 使 是 这 种 对 于 理解 蝇 白 质 折 著 有 很 大 局 限 
性 的 方法 ， 也 需要 解决 困难 的 NP 问题 。 
































2; 物理 学 


寻找 物理 系统 能 量 的 最 低 值 是 一 个 NP 问题 ， 物 理 系统 可 以 是 相互 作用 
的 磁性 粒子 群 ， 或 是 一 堆肥 旺 泡 ， 等 等 。 人 们 不 知道 如 何 有 效 找到 这 些 
系统 最 低 的 能 量 状 态 。 难 道 物理 系统 不 是 总 会 最 终 达 到 最 低能 量 状态 
My 不 是。 


考虑 一 个 弹 珠 放置 在 如 图 3-17 所 示 的 曲面 上 。 这 个 弹 珠 最 终 停 在 3.0 处 才 
能 达到 最 低 势 能 。 如 果 它 一 开始 处 于 1.0 位 置 ， 它 将 保持 静止 ， 除 非 推 
它 一 把 。 从 中 可 以 看 出 ， 物 理学 系统 并 非 总 会 最 终 达 到 最 低能 量 状态 。 
找到 复杂 系统 的 最 小 能 量 ， 对 于 计算 机 和 系统 本 号 来 说 ， 都 很 困难 。 





0.5 1.0 了 区 2.0 25 3.0 3:5 4.0 
y=7x—55x :+148x—159x+64, 0.5<x<4.0 


图 3-17 物理 系统 的 图 表 


量子 力学 可 能 帮 我 们 解决 部 分 困难 的 NP 问题 ， 而 不 是 全 部 。 这 部 分 内 
容 我 们 将 在 第 9 章 深入 讨论 。 





3. 经 济 学 


一 个 对 冲 基 金 经 理 需 要 从 许多 复 林 的 投资 工具 中 作出 选择 。 一 个 预算 有 
限 的 消费 者 走 进 超市 ， 面 对 各 种 商品 难以 取舍 。 他 们 其 实 才 在 求解 困难 
的 NP 计算 问题 。 由 于 人 们 并 不 是 总 能 有 效 解决 这 些 问题 ， 通 常 做 出 的 
决策 都 是 次 优 的 。 市 场 上 的 这 些 计算 效率 低下 对 于 我 们 的 经 济 乃 至 整个 
社会 的 不 利 影响 究竟 有 多 大 ? 这 是 个 很 棒 的 问题 ， 可 惜 我 们 无 法 给 出 很 





棒 的 答案 。 


约 验 :纳什 是 一 个 经 济 学 家 ， 传 记 图 书 《 美 丽 心灵 》 (A Beautiful 
Mind) 和 同名 电影 都 从 一 定 程度 上 展现 了 他 的 生平 。 纳 什 获 得 (人 述 到 
的 ) 详 贝 尔 奖 ， 是 因为 他 证 明了 个 体 间 根据 策略 互动 时 存在 一 个 均衡 状 
态 ， 在 此 状态 下 所 有 个 体 采 取 的 策略 经 过 博 列 达到 均衡 ， 即 任何 一 方 改 
变 策 略 的 做 法 ， 都 不 会 为 任何 人 市 来 利益 。 纳 什 的 存在 性 证 明 没 有 给 出 
如 何 找 到 这 些 策 略 的 方法 ， 计 算 机 科学 家 目前 得 到 的 证 据 显 示 ， 找 到 这 
样 的 策略 可 能 是 一 个 计算 上 困难 的 问题 。 问 题 的 难度 预示 着 市 场 本 里 并 
非 总 能 找到 这 样 的 均衡 状态 ， 也 就 是 说 市 场 将 保持 持续 波动 ， 人 们 也 将 
不 断 改 变 策略 以 奶 求 更 好 的 结 


4. 数学 


1928 年 ， 数 学 泰斗 大 卫 : 希 尔 但 特 提 出 了 他 伟大 的 判定 性 问题 
(Entscheidungsproblem) ， 即 能 人 否 找到 一 个 能 正确 判定 任意 数学 命题 真 
伪 的 算法 。1931 年 库 尔 特 : 哥 德尔 证 明 ， 必 然 存 在 某 些 命题 ， 它 们 根本 
不 能 被 任何 公理 系统 的 集合 证 实 或 证 仿 。 受 哥 德 尔 工 作 的 影响 ， 几 年 
后 ， 阿 隆 索 : 丘 奇 和 阿兰 :图 灵 分 别 独立 证 明了 不 存在 满足 判定 性 问题 要 
求 的 算法 。 


但 如 果 我 们 做 出 限定 ， 即 命题 所 需 证 明 的 长 度 必须 短 到 可 以 在 一 本 很 注 
的 书 上 写 出 来 ， 这 样 有 可 能 找到 判定 算法 吗 ? 我 们 可 以 通过 计算 来 求解 
这 个 问题 ， 只 要 穷 举 对 于 给 定数 学 命题 的 所 有 可 能 的 短小 证 明 残 可 以 

了 。 这 是 一 个 NP 问 题 ， 因 为 如 果 给 定 一 个 证 明 ， 我 们 容易 判断 它 是 否 

有 效 ， 但 是 找到 一 个 有 效 证 明 实 际 上 很 困难 。 这 也 是 为 什么 数学 家 能 通 
过 巧妙 地 证 明 茶 些 数学 命题 而 博得 声誉 的 原因 。 

有 了 时候 找 出 让 系 些 形 式 简 单 的 逻辑 表达 式 为 真 的 方法 都 很 困难 。 对 这 个 


问题 的 研究 直接 促成 了 一 个 能 将 大 部 分 NP 问题 都 联系 起 来 的 理论 的 形 
成 。 我 们 在 下 一 章 讲 讲 这 个 故事 。 





3.10 ”Icosian 游 戏 的 一 个 解 
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图 3-18 ”Icosian 的 解 


第 4 革 NP 中 最 难 的 问题 


心理 学 家 以 数学 家 为 研究 对 象 做 了 一 个 实验 。 把 数学 家 关 在 一 个 小 木 
屋 里 ， 地 上 放 一 些 引火 物 、 一 张 桌 子 ， 果 子 上 有 一 桶 水 。 然 后 心理 学 
家 点 着 了 地 上 的 引火 物 。 数 学 家 提起 桌 上 的 水 桶 把 火 扑 灭 了 。 


到 目前 为 止 一 切 正常 。 心 理学 家 再 次 进行 实验 ， 还 是 把 数学 家 关 在 那 
个 有 果子 、 水 桶 和 引火 物 的 小 屋 里 ， 但 这 次 ， 水 桶 是 放 在 地 上 的 ， 靠 
近 那 堆 引 火 物 。 然 后 心理 学 家 又 放 了 火 。 数 学 家 提起 水 桶 ， 把 它 放 到 
果子 上 ， 然 后 就 等 厦 。 心 理学 家 和 同事 们 好 容易 才 把 数学 家 及 时 从 即 
将 烧 塌 的 小 木屋 里 救出 来 。 


心理 学 家 问 数学 家 :“ 为 什么 不 像 上 次 一 样 把 火 扑 灭 ? ”数学 家 回 
答 :“ 我 已 把 问题 归 约 到 一 个 之 前 解决 过 的 情形 。” 


一 一 一 个 老生 常 谈 的 数学 笑话 











4.1 第 一 个 NP 完 全 问题 


汤姆 赫 尔 在 1970 年 担任 多 伦 多 大 学 计算 机 科学 系 的 主任 ， 他 想 聘 用 斯 
带 分 ' 库 元 ， 当 时 加 州 大 学 伯克利 分 校 刚 刚 拒绝 了 库 殉 的 终身 教授 职位 
申请 。 库 殉 喜 欢 帆 板 运动 ， 于 是 赫 尔 带 他 到 安大略 湖 玩 ， 给 他 展示 在 多 
伦 多 附近 也 能 进行 帆 板 运动 ， 和 旧金山 湾 是 一 样 的 。 这 个 小 伎俩 奏效 
了 ， 斯 带 耸 ' 库 元 于 1970 年 秋天 加 入 了 多 伦 多 大 学 的 教 席 。 当 年 的 赫 尔 
真 可 谓 慧 眼 识 珠 ， 因 为 在 那 之 后 不 久 ， 库 死 就 成 为 加 拿 大 最 著名 的 计算 
机 科学 家 。 


库 克 研究 逻辑 学 和 计算 机 科学 的 联系 。 那 年 秋天 ， 他 问 即 将 在 来 年 五 月 
召开 的 第 三 届 ACM 计 算 理 论 年 会 (ACM Symposium on the Theory of 
Computing，STOC) 提交 了 一 篇 论文 。 这 篇 论文 最 初 的 结论 已 经 被 遗 环 
了 ， 不 过 它 在 当时 引起 了 足够 大 的 兴趣 ， 被 安排 在 会 上 宣读 。 在 准备 会 
议 期 间 ， 库 克 重 写 了 论文 以 加 入 最 新 的 工作 成 采 ， 而 这 篇 名 为 “理论 证 
明 过 程 的 复杂 上 度 ”(The Complexitiy of Theorem-Proving Procedures) 的 
论文 ， 将 首次 把 PNP 问 题 呈 现在 世人 面前 ， 进 而 改变 历史 。 


为 更 好 理解 库 克 的 论文 ， 让 我 们 回 尖 看 看 上 一 章 的 团 问题 。 团 是 一 群 互 


为 朋友 的 敌 友 国 居 民 。 在 下 面 这 张 好 友 关 系 图 中 ，Alex、Cathy 和 Eric 是 
一 个 团 ， 而 Alex、David 和 Eric 则 不 是 ， 因 为 Alex 和 David 是 敌人 而 非 朋 
友 ， 


Alex 
David 


Barbara 


Eric 


Cathy 
图 4-1 


你 可 能 记得 ， 在 敌 友 国有 一 个 半 地 下 社会 组 织 叫 阿尔 法 会 ， 据 说 里 面 的 
成 员 都 互 为 朋友 ， 也 就 是 次 他 们 构成 一 个 很 大 的 团 。 假 设 阿 尔 法 会 真 的 








是 一 个 团 ， 我 们 能 否 从 上 面 的 好 友 关 系 图 看 出 一 些 端倪 ? 首先 不 能 排除 
任何 一 个 人 是 阿尔 法 会 成 员 的 可 能 。Alex 可 能 在 阿尔 法 会 ，David 也 有 
可 能 。 但 是 Alex 和 David 不 可 能 同时 在 阿尔 法 会 ， 因 为 他 们 是 敌人 。 所 
以 要 么 Alex 不 在 阿尔 法 会 ， 要 么 David 不 在 。 让 我 们 把 这 个 逻辑 表达 式 
村 下 米 ; 


Alex not in Alpha Society OR David not in Alpha Society 


这 里 的 OR 不 具有 排斥 性 ， 即 有 可 能 Alex 和 David 都 不 在 阿尔 法 会 。 由 于 
Alex 和 Barbara 是 敌人 ， 上 所 以 我 们 也 知道 这 两 个 人 不 可 能 同时 在 会 里 : 


这 两 个 逻辑 表达 式 必 须 同时 为 真 ， 所 以 我 们 有 : 

(Alex not in Alpha Society OR David not in Alpha Society) AND 

(Alex not in Alpha Society OR Barbara not in Alpha Society) 

既然 Barbara 和 David 是 朋友 ， 他 们 可 能 都 在 阿尔 法 会 ， 然 而 这 个 逻辑 与 
上 述 表 达 式 并 不 冲突 。 把 完整 的 关系 图 用 逻辑 表示 出 来 ， 我 们 得 到 : 


(Alex not in Alpha Society OR David not in Alpha Society) AND 
(Alex not in Alpha Society OR Barbara not in Alpha Society) AND 





(David not in Alpha Society OR Cathy not in Alpha Society) AND 
(Cathy not in Alpha Society OR Barbara not in Alpha Society) 





如 果 Alex、Cathy 和 Eric 在 阿尔 法 会 ， 而 Barbara 和 David 不 在 ， 表 达 式 为 
真 ， 因 为 每 个 OR 项 中 都 因 存 在 不 是 会 员 的 人 而 得 到 满足 。 然 而 ， 如 果 
Alex、David 和 Eric 在 会 中 ， 则 表达 式 为 假 : (Alex not in Alpha 
Society OR David not in Alpha Society) 这 部 分 不 满足 ， 因 为 
Alex 和 David 都 在 会 中 。 








表达 式 很 好 地 表达 了 团 问 题 。 当 且 仅 当 阿 尔 法 会 的 成 员 们 组 成 一 个 团 
时 ， 表 达 式 为 真 。 


我 们 可 以 为 敌 友 国 的 2 万 居民 生成 一 个 类 似 的 逻辑 表达 式 ， 将 它 简 写 为 
中。 可 能 很 长 ， 有 几 百 万 个 字符 ， 但 是 计算 机 能 很 容易 地 存 下 它 。 如 
果 阿 尔 法 会 真是 一 个 团 ， 则 表达 式 为 真 。 

















我 们 有 男 一 个 表达 式 50， 它 在 阿尔 法 会 有 至 少 50 个 成 员 时 为 真 。 我 不 
想 具体 讲 如 何 写 出 50， 它 的 构造 方法 和 最 早 的 电子 计算 机 做 加 法 的 方 
式 是 一 样 的 。 


如 果 把 两 个 表达 式 结 合 起 来 ， 我 们 就 得 到 ($58@ AND 0)， 它 在 “阿尔 法 
会 是 一 个 团 ， 且 至 少 有 50 个 成 员 * 时 为 真 。 反 过 来 说 ， 如 果 阿 尔 法 会 令 
(V58 AND 0) 为 真 ， 那 么 它 是 一 个 至 少 有 50 个 元 素 的 团 。 


假设 我 们 有 一 个 快速 算法 ， 它 能 告诉 我 们 给 定 的 逻辑 表达 式 是 否 能 被 满 
足 。 如 果 我 们 给 它 ($56@ AND 9)， 然 后 它 回 答 :“ 是 的 ，(Y58 AND 0) 
可 以 被 满足 。? 则 敌 友 国 存在 一 个 50 人 的 团 。 如 果 ($58@ AND 0) 不 可 以 
被 满足 ， 则 那里 不 存在 这 样 的 团 。 解 决 了 这 个 可 满足 性 问题 ， 你 就 能 解 
决 团 问 题 。 


我 们 刚刚 描述 了 一 个 计算 机 科学 中 最 关键 的 概念 : 归 约 。 我 们 把 寻找 团 
的 问题 归 约 到 检 碍 逻辑 表达 式 的 可 满足 性 的 问题 。 现 在 只 要 我 们 有 解决 
可 满足 性 问题 的 算法 ， 就 可 以 通过 很 容易 的 变换 ， 得 到 团 问题 的 求解 算 
法 。 团 问题 的 求解 至 少 和 可 满足 性 的 求解 一 样 容易 。 如 果 可 满足 性 是 容 
易 求解 的 ， 那 么 团 问题 也 是 。 如 果 团 问题 没有 有 效 解法 ， 那 么 可 满足 性 
问题 也 没有 。 


能 归 约 到 可 满足 性 问题 的 不 仅 是 团 问 题 ， 而 且 还 包括 我 们 前 面 讨论 过 的 
其 他 NP 问题 ， 包 括 旅行 推销 员 问 题 、 哈 密 顿 回路 、 最 大 割 和 地 图 填 色 
问题 。 事 实 上 ， 斯 带 耸 : 库 克 证 明了 NP 中 的 每 一 个 问题 都 能 通过 某 种 方 
式 归 约 到 可 满足 性 问题 。 解 决 了 可 满足 性 问题 ， 你 就 能 解决 所 有 的 NP 
问题 。 如 果 你 有 解决 可 满足 性 的 有 效 算法 ， 我 们 就 能 快速 解决 所 有 容易 
检查 特定 解 有 效 性 的 问题 ， 也 就 是 说 证 明了 P=NP。 只 要 你 有 一 个 解决 
可 满足 性 的 有 效 算法 ， 那 么 区 雷 研究 所 提供 的 几 百 万 类 元 奖金 就 是 你 的 
J 

















1971 年 5 月 4 日 ， 在 当时 的 俄 雍 俄 州 榭 柯 高 地 斯 托 弗 的 萨 默 塞 特 酒 店 召 开 
的 STOC 上 ， 斯 蒂 分 . 库 殉 宣读 了 目 己 的 论文 。 


结果 表明 ， 可 满足 性 问题 可 以 作为 一 个 相对 有 用 但 尚未 存在 有 效 计算 
方法 的 符 选 诛 题 来 研究 ， 并 且 我 认为 值得 投入 更 多 精力 来 证 明 这 个 猜 
想 。 找 到 它 的 证 明 将 可 能 带 来 重大 的 突破 。 








P/NP 问 题 从 此 诞生 了 。 


4.2 21 个 问题 





库 死 的 论文 刚刚 发 表 时 ， 尽 管 结 末 的 重要 性 得 到 了 肯定 ， 但 也 没有 立即 
改变 学 术 研 究 的 方向 。 毕 竟 对 可 满足 性 问题 感 兴趣 的 人 不 多 ， 并 且 大 家 
对 NP 问题 还 不 熟悉 。 斯 带 芬 : 库 克 甚至 没有 在 论文 中 提 到 NP 这 个 缩写 ， 
而 用 了 它 的 全 名 “不 确定 性 多 项 式 时 间 ” (nondeterministic polynomial 
time) 。 但 不 久 以 后 ， 情 况 随 着 伯克利 教授 理 查 德 : 卡 普 的 一 篇 承 上 局 下 
的 论文 而 改变 了 。 


看 过 库 殉 的 论文 以 后 ， 卡 普 意 识 到 有 一 种 方法 可 以 把 可 满足 性 归 约 到 团 
问题 。 卡 普 建 立 了 一 个 简单 的 计算 过 程 ， 它 能 把 给 定 逻 辑 表 达 式 转换 成 
相应 的 好 友 关 系 图 ， 并 有 当 且 仅 当 关系 图 上 存在 等 于 某 个 数 的 团 时 ， 表 
达 式 为 真 。 任 何 能 解决 团 问题 的 算法 都 可 以 用 来 解决 满足 性 问题 。 库 克 
表明 了 可 满足 性 是 NP 问 题 中 最 难 的 。 而 卡 普 表明 ， 团 问题 至 少 和 可 满 
足 性 问题 一 样 难 。 这 样 一 来 ， 团 问题 就 成 为 NP 最 难 的 问题 之 一 。 和 可 
满足 性 问题 一 样 ， 如 果 我 们 找到 了 团 问 题 的 快速 解法 ， 那 么 所 有 NP 类 
问题 束 迎 为 而 解 ， 从 而 证 明 P=NP。 


库 克 表明 了 如 何 把 类 似 团 这 样 的 问题 归 约 到 可 满足 性 问题 。 卡 普 则 表明 
可 满足 性 可 归 约 为 团 问 题 。 这 两 个 表面 看 上 去 非常 不 同 的 问题 ， 在 计算 
角度 上 竟然 是 相同 的 。 可 满足 性 容易 计算 的 充分 必要 条 件 是 团 问题 容易 
计算 ， 而 后 者 的 充分 必要 条 件 是 P=NP。 


卡 普 不 仅 证 明了 团 问题 是 NP 中 最 难 的 问题 之 一 ， 而 且 找 出 了 其 他 19 个 
同样 难度 的 重要 问题 ， 包 括 分 割 难题 、 旅 行 推 销 员 、 哈 密 顿 回路 、 地 图 
填 色 以 及 最 大 制 。 只 要 有 效 解 决 了 这 些 问题 中 的 任意 一 个 ， 你 就 能 解决 
所 有 问题 并 证 明 P=NP。 如 果 说 PzNP， 那 么 这 21 个 问题 (包括 可 满足 性 
问题 ) 没有 一 个 能 被 快速 地 解决 。 

卡 普 并 不 是 凭空 创造 了 这 21 个 问题 ， 对 解决 这 些 问 题 感 兴趣 的 也 不 仅 是 
数学 家 和 计算 机 科学 家 。 其 中 的 许多 问题 来 自 现 实 世 界 。 


比如 可 口 可 乐 公司 ， 它 旗下 的 饮料 品牌 超过 3000 个 ， 行 销 世界 各 地 。 一 
个 可 口 可 乐 的 灌 装 工厂 可 能 会 生产 几 特 种 不 同 的 饮料 产品 。 每 个 工厂 都 
有 数 台 机 器 需要 进行 一 系列 的 作业 ， 混 合 每 种 饮料 所 需 的 部 分 原料 。 这 























些 机 器 可 以 生产 各 种 产品 ， 而 灌 装 工厂 需要 合理 调度 机 器 的 作业 ， 以 达 
到 其 吞吐 量 的 最 大 值 ， 从 而 在 最 短 时 间 内 生产 出 最 多 的 饮料 产品 。 这 是 
一 个 作业 调度 问题 ， 它 也 在 卡 普 列 出 的 21 个 问题 之 中 ， 其 求解 难度 不 亚 
于 任何 其 他 的 NP 问 题 。 


从 电子 计算 机 诞生 之 日 起 ， 科 学 家 和 程序 员 就 在 尽 最 大 努力 ， 研 发 解决 
作业 调度 问题 的 最 佳 算法 ， 因 为 一 个 很 小 的 调度 改进 就 可 能 为 东 个 企业 
节省 数 百 万 美元 。 还 没有 人 与 出 对 所 有 调度 问题 都 能 给 出 最 好 方案 的 算 
法 。 卡 普 证 明 ， 甚 至 连 调度 的 简单 改进 也 是 一 个 难度 不 亚 于 任意 NP 问 
题 的 难题 ， 这 也 立即 揭示 了 为 什么 人 们 找 不 到 那些 调度 改进 算法 。 


不 仅 是 大 公司 会 天 心 这 些 问 题 。 假 设 你 带 家 人 去 迪士尼 乐园 春游 ， 因 为 
放假 所 以 要 排 长 队 。 你 想 尽 可 能 多 玩 些 好 的 娱 乐 景点 ， 减 少 排 队 浪 费 的 
时 间 。《 人 迪士尼 乐园 非 官 方 指南 》 的 作者 想 出 了 一 整套 如 何 减少 等 等 时 
间 的 游玩 攻略 ， 但 同时 他 们 也 承认 自己 在 做 一 件 很 困难 的 事 。 


魔法 王国 景区 21 个 景点 一 日 游 ， 针 对 成 人 的 可 能 游览 方案 总 数 是 让 人 
震惊 的 51 090 942 171 709 440 000 种 。 那 可 是 超过 5100 亿 亿 种 的 组 
合 ， 大 概 是 地 球 上 沙 粒 总 数 的 6 倍 。 要 是 再 考虑 上 快速 排 号 系统 
(CFASTPASS) 、 游 行 、 吃 饭 和 休息 等 ， 就 更 复杂 了 ， 组 合 的 数量 还 
得 增加 好 多 。 


类 似 的 问题 也 困扰 了 科学 家 们 很 多 年 。 比如 ， 人 快递 公司 会 关心 如 何 安 
排 每 个 送 货 员 的 路 线 ， 证 行驶 距离 最 短 ， 从 而 节省 时 间 和 燃料 。 事实 
上 ， 这 类 “如 何以 最 小 的 代价 访问 多 个 地 点 ”的 问题 十 分 普遍 ， 人 们 给 它 
们 起 了 一 个 外 号 : 旅行 推销 员 问 题 。 


许多 科学 家 等 试 过 找 出 旅行 推销 员 问 题 的 最 佳 解 法 。 还 有 人 试 过 为 作业 
调度 问题 找到 一 个 高 明 的 算法 。 男 外 人 们 还 尝试 过 求解 团 、 最 大 制 以 及 
其 他 卡 普 所 列 出 的 算法 。 卡 普 的 论文 意味 大 所 有 这 些 研究 者 研究 的 其 实 
古 一 个 问题 ， 因 为 如 果菜 人 为 其 中 茶 一 个 算法 找 出 了 有 效 的 解法 ， 那 么 
所 有 其 余 的 算法 就 迎刃而解 了 。 


同 理 ， 所 有 这 些 独立 工作 的 研究 者 之 中 没有 一 个 人 能 对 他 们 所 研究 的 特 
定 问题 找到 有 效 的 解法 ， 这 很 可 能 上 暗示 了 PzxNP， 或 者 至 少 可 以 说 ， 很 
难为 这 些 问题 中 的 任意 一 个 找到 好 的 算法 。 所 以 作业 调度 的 技术 员 们 可 
以 理直气壮 地 告诉 老板 ， 我 们 是 找 不 到 机 器 上 最 好 的 作业 调度 方法 ， 但 









































不 只 是 我 们 不 行 ， 连 奥兰多 的 那 帮 机 灵 风 都 搞 不 定 迪 士 尼 乐园 的 游 哆 线 
路 规划 呢 。 


而 卡 普 的 工作 ， 一 下 子 就 把 所 有 这 些 出 了 名 的 难以 解决 的 计算 问题 联系 
到 了 一 起 。 从 此 ，P/NP 问 题 成 为 众人 瞩目 的 焦点 。 


每 年 计算 机 协会 都 会 颁发 ACM 图 灵 奖 ， 其 地 位 相当 于 计算 机 科学 界 的 
诡 贝 尔 奖 。 该 奖 得 名 于 数学 家 阿兰 .图 灵 ， 他 在 20 世 纪 30 年 代为 计算 机 
科学 况 定 了 基础 。ACM 将 1982 年 的 图 灵 奖 授予 斯 带 芬 : 库 殉 ， 以 表彰 他 
为 PNP 问题 的 建立 所 做 出 的 杰出 页 献 。 但 一 个 图 灵 奖 还 不 够 ， 理 查 德 : 
卡 普 于 1985 年 也 获得 了 图 灵 奖 ， 奖 励 他 在 算法 理论 方面 的 杰出 工作 ， 特 
别 是 列 出 了 21 个 NP 完全 问题 。 








4.3 起 个 好 名 字 有 那么 重要 吗 


卡 普 的 论文 给 出 了 我 们 今天 使 用 的 P 和 NP 这 些 名 字 。 但 是 该 怎么 称呼 那 
些 NP 中 最 难 的 问题 呢 ? 库 元 用 了 一 个 非常 学 术 的 名 称 deg({DNF 重 言 

式 })， 而 卡 普 使 用 了 术语 (多 项 式 时 间 〉 完 全。 可 是 这 些 名 字 太 别扭 

Ts 





高 德 纳 接 手 了 这 个 命名 问题 。 鉴 于 他 一 贯 杰 出 的 研究 工作 以 及 宛如 丰碑 
般 的 三 卷 巨 著 《 计 算 机 程序 设计 艺术 》1， 高 德 纳 在 1974 年 获得 图 灵 
奖 。 由 于 认识 到 了 P/NP 问 题 至 关 重要 的 作用 ， 高 德 纳 想 在 第 4 卷 中 最 终 
敲定 这 个 NP 中 最 难 问题 集合 的 命名 。1973 年 ， 他 通过 普通 邮件 做 了 一 
次 投票 调查 。 他 直到 今天 都 坚持 不 用 电子 邮件 ， 这 在 业界 是 很 有 名 的 。 
但 在 1973 年 ， 只 有 普通 邮件 可 用 。 


1 《计算 机 程序 设计 艺术 》 卷 1 、 卷 2、 卷 3、 卷 4A 的 英文 版 均 已 由 人 民 邮 电 出 版 社 出 版 ， 中 文 
版 也 会 相继 呈现 给 读者 ， 详 情 请 登录 图 灵 社 区 〈www.ituring.com.cn) 查阅 相关 图 书 。 编者 
注 


高 德 纳 在 投票 中 给 出 的 几 个 候选 项 herculean 〈 艰 巨 ) 、 

formidable 《可怕 〉 和 arduous〈 费 劲 ) ， 都 不 怎么 受 欢 迎 。 他 收 到 了 许 
多 来 信 建 议 ， 有 些 很 直 白 ， 如 intractable (项 固 ) 和 obstinate 〈 执 扬 ) ， 
有 些 则 更 加 口语 化 ， 如 hard-boiled (原意 是 者 得 很 硬 的 蛋 ， 可 能 是 在 向 
库 克 致敬 *) 和 hard-ass( 抗 接 的 混蛋 ， 简 直 像 可 满足 性 问题 一 样 难 

哺 〉。 














































































































2 库 殉 (Cook) 这 个 姓 的 原意 为 “厨师 ”。 一 -一 译 者 注 





最 终 获 胜 的 来 信 建 议 是 “NP-complete”(NP 完 全 ) ， 它 由 新 泽 西 州 贝 尔 
实验 室 的 几 个 人 提出 ， 是 那里 的 研究 者 经 过 多 次 讨论 之 后 产生 

的 。“complete”( 完 全 或 完备 ) 这 个 词 出 自 数 学 逻辑 学 ， 一 个 事实 集合 
被 称 为 完备 的 ， 束 是 说 它 能 解释 某 些 逻辑 系统 的 所 有 真 命题 。 类 似 
地 ，“NP 完 全 ”表示 这 些 NP 问 题 的 集合 强大 到 能 够 用 来 解决 任何 其 他 的 
NP 问题 。 


高 德 纳 对 这 个 民选 结果 不 太 满 意 ， 但 也 没有 觉得 它 差 到 让 人 活 不 下 去 的 





地 步 。 他 本 人 特别 想 要 找 一 个 英文 词 ， 既 能 捕 欣 “ 困 难 的 搜索 问题 > 这 个 
直观 的 意象 ， 又 要 下 琅 上 口 ， 便 于 同 大 众 普及 。1974 年 ， 高 德 纳 总 结 了 
他 的 调查 过 程 ， 文 中 写 道 : “NP 完 全 这 个 名 字 其 实学 术 气 电 有 点 儿 
浓 ， 不 好 向 大 众 推广 ， 但 也 没有 差 到 不 能 用 的 地 步 。” 


“NP 完 全 ”很 快 成 为 标准 术语 。 高 德 纳 用 了 大 概 40 年 才 完成 巨著 的 第 4 


其 实 局 德 纳 当 年 本 应 该 坚持 己见 ， 为 “NP 完全 ”， 甚 至 “P” 和 “NP” 这 些 概 
念 敲定 一 些 不 那么 学 术 的 术语 。P/NP 问 题 的 重要 性 已 经 远 远 超出 了 计算 
机 科学 领域 ， 而 这 种 将 术语 的 首 字母 缩写 的 命名 方式 ， 阻 碍 了 门外汉 对 
其 重要 性 的 认 知 。 但 这 些 术语 在 几 十 年 后 已 经 在 文化 中 根深 蒂 回 ， 即 使 
现在 我 们 想到 了 更 好 的 名 字 ， 翁 怕 也 不 好 纠正 了 。 


高 德 纳 也 意识 到 ， 如 果 最 终 证 明 P=NP， 也 就 是 说 NP 完 全 问题 其 实 就 是 
P 中 的 问题 ， 那 么 之 前 为 它 起 名 字 而 做 出 的 种 种 努力 岂 不 全 都 白费 了 。 
但 是 高 德 纳 说 了 :“ 即 使 将 来 可 能 觉得 尴 罚 ， 我 也 愿意 冒 这 个 险 一 一 我 
将 奖 给 第 一 个 证 明 P=NP 的 人 一 只 活 蹦 乱 跳 的 火 鸡 。” 所 以 现在 证 明 
P=NP 的 人 可 以 赢得 100 万 美元 ， 外 加 一 只 火 鸡 。 


























4.4 超越 卡 普 的 工作 


在 卡 普 的 论文 之 后 ， 计 算 机 科学 界 掀起 了 一 个 寻找 并 证 明 各 种 问题 是 人 否 
属于 NP 完 全 的 热潮 。 在 接 下 来 的 几 年 里 ， 教 授 和 研究 生 们 成 功 证 明了 
许多 已 知 的 搜索 问题 (以 及 一 些 新 问题 ) 是 NP 完全 的 。 一 本 1979 年 出 
版 的 书 ! 中 列举 了 三 百 多 个 主要 的 NP 完全 问题 。NP 完 全 问题 持续 在 各 个 
领域 涌现 ， 如 计算 机 科学 、 物 理学 、 生 物 学 、 经 济 学 ， 以 及 其 他 许多 林 
登 到 困难 顶峰 的 学 科 。Google 学 术 搜 索 NP-Complete 将 返回 超过 138 000 
篇 科研 文献 ， 时 间 跨 度 从 1972 年 到 2011 年 ， 单 是 2011 年 就 有 近 1 万 篇 。 
我 们 在 此 无 法 一 一 列举 ， 只 从 中 挑选 几 篇 ， 看 看 这 些 文章 是 什么 风格 。 


1 Computers and Intractability: A Guide to the Theory of NP-Completeness, 作者 Michael Garey 和 
David Johnson (New York: W. H. Freeman, 1979) 。 





1. 支配 集 (Dominating Set) 


敌 友 国 是 否 存 在 这 样 的 50 个 人 : 其 余 的 人 和 这 50 个 人 中 的 至 少 1 个 是 朋 
友 ? NP 完全 问题 。 


2. 三 角 切 分 问题 (Partition into Triangles) 


敌 友 国 理工 学 院 的 每 个 宿舍 只 能 容纳 三 名 学 生 。 我 们 能 把 所 有 敌人 都 安 
排 在 不 同 的 宿舍 里 吗 ? NP 完全 问题 。 


3. 大 规模 数 独 游戏 


数 独 〈Sudoku) 是 一 种 起 源 于 日 本 的 填 数 字 游 戏 ， 使 用 一 个 9x9 的 格 
子 ， 如 下 图 所 示 。 








图 4-2 数 独 


数 独 的 游戏 目标 是 填 满 所 有 空格 ， 并 使 每 一 行 、 每 一 列 和 由 黑 线 标 出 的 
3x3 小 方 格 中 的 数字 分 别 是 1 到 9 的 不 重复 的 数字 。 





图 4-3 数 独 的 解 


数 独 是 NP 问 题 ， 因 为 很 好 检查 一 个 解 。 找 到 一 个 解 有 多 难 ? 不 太 困 
难 。 使 用 简单 的 回溯 算法 ， 普 通 计算 机 可 以 在 几 秒 内 找到 一 个 有 效 解 。 
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图 4-4 大 规模 的 数 独 


但 是 如 果 谜 题 的 规模 变 得 更 大 ， 像 上 面 这 个 25x25 的 版 本 ， 要 求 每 行 、 
每 列 和 小 方块 中 填 入 A 到 Y 且 不 重复 的 字母 ， 会 发 生 什么 呢 ? 


回 普 通 计算 机 束 得 算 好 长 时 间 了， 而 100x100 的 数 独 游戏 能 打败 当今 
最 快 的 机 器 。 


大 规模 的 数 独 游戏 是 NP 完全 问题 。 你 自 认 为 是 数 独 高 手 ? 如 末 你 能 6 
徘 地 解决 大 规模 的 数 独 ， 那 么 你 也 能 解决 可 满足 性 问题 、 旅 行 推销 员 问 
题 ， 还 有 其 他 几 干 个 NP 完全 问题 


数 独 可 不 是 桌面 游戏 中 唯一 一 个 NP 完全 问题 。 来 看 微软 Windows 系 统 自 
市 的 扫雷 游戏 。 
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图 4-5 ”扫雷 


每 个 小 方块 埋 着 一 个 数字 或 者 地 雷 ， 数 字 代表 临近 的 方块 (包括 水 平 、 
垂直 和 对 角 线 相 邻 ) 总 共有 几 个 地 雷 。 在 茶 个 不 是 地 雷 的 方块 上 点 一 下 
会 显示 出 下 面 的 数字 。 如 果 你 觉得 方 其 下 面 有 地 雷 ， 就 标 一 个 小 旗子 。 
点 中 地 雷 你 就 输 了 。 判 断 能 否 玩 遍 一 个 大 规模 的 扫雷 游戏 也 是 NP 完 全 
问题 。 这 是 上 面 那 张 图 里 剩 下 的 地 雷 。 
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图 4-6 扫雷 失败 


四 TETRIS 


TIME 67 
POINTS 90 


前 加 





图 4-7 俄罗斯 方块 


当然 还 有 俄罗斯 方块 。 玩 家 平移 和 旋转 各 种 下 沙 的 积木 ， 填 满 一 行 的 那 
一 刻 整 行 会 消失 ， 游 戏 目 标 是 不 让 整个 画面 都 被 方块 填 满 ， 坚 持 尽 可 能 
长 的 时 间 。 


积木 分 很 多 种 形状 。 


日 
了 


图 4-8 ”俄罗斯 方块 的 积 


经 典 俄罗斯 方块 游戏 中 你 不 知道 下 一 块 积木 的 形状 。 但 即使 你 提前 知道 
了 各 种 形状 的 积木 到 来 的 次 序 ， 如 何 把 俄罗斯 方块 玩 到 最 好 也 是 一 个 


NP 完 全 问题 。 


谁 曾 想 把 数 独 、 扫 雷 和 俄罗斯 方块 这 些 游戏 玩 好 ， 就 可 以 证 明 P=NP 从 
而 解决 我 们 这 一 代 面 临 的 最 大 的 挑战 呢 ? 





图 4-9 魔方。 图 片 作 者 为 Tom van der Zanden 


魔方 叉 怎 么 样 呢 ? 即使 是 3x3x3 的 小 魔方 ， 一 般 人 也 得 花 不 少 工夫 才能 
知道 如 何 复原 ， 而 求解 更 大 的 魔方 的 难度 可 想 而 知 。 


其 实 不 算 太 难 。 我 们 对 于 解决 更 大 规模 的 魔方 复原 问题 有 一 些 很 快 的 算 





法 ， 它 们 都 基于 一 个 叫做 群 论 的 数学 分 支 。 这 些 算法 不 能 保证 找到 全 局 
最 少 步骤 的 解法 ， 但 是 总 能 找到 足够 短 的 方法 ， 从 任何 可 能 的 打 乱 方式 
开始 将 魔方 复原 。 


与 玩 好 俄罗斯 方块 、 扫 雷 和 数 独 的 困难 程度 相 比 ， 复 原 魔方 的 问题 容易 


得 出 奇 。 


而 双人 人 对战 游 戏 ， 如 国际 象棋 、 跳 横 、 黑 白 棋 和 围棋 ， 它 们 的 难度 又 如 
何 呢 ?这 些 游戏 的 大 规模 版 本 ， 其 难度 和 可 满足 性 问题 等 NP 完全 问题 
的 难度 是 相当 的 。 但 是 这 些 双人 游戏 不 属于 NP 类 问题 。 比 如 我 告诉 
你 ， 这 盘 国际 象棋 肯定 是 白 方 局 ， 最 后 一 步 是 三 列 革 吃 王 ， 你 根本 没 法 
验证 我 的 话 。 计 算 机 科学 家 基本 上 都 认为 国际 象棋 、 跳 棋 、 黑 白 棋 和 转 
棋 的 难度 均 大 于 任何 NP 问 题 。 


4. 旧 脏 交换 


正常 人 有 两 个 健康 的 肾 来 将 体内 的 代谢 废物 滤 出 体外 。 如 果 只 剩 一 个 
崩 ， 人 还 是 可 以 过 正常 的 生活 。 如 末 两 个 肾 都 不 能 用 ， 束 必须 用 透析 来 
维持 生命 ， 这 不 仅 需要 耗费 大 量 金钱 和 时 间 ， 而 且 时 刻 都 有 可 能 死亡 。 


有 两 个 健康 肯 的 人 可 以 捐献 出 其 中 一 个 ， 挽 救 双 明 豆 竟 的 病人 ， 前 提 是 
捐献 者 的 肯 和 受 捐 者 的 吴 体 相 容 。 通 过 简单 的 抽 血 就 可 进行 这 种 相 容 性 
测试 。 


假如 Alice 不 幸 双 肾 误 竭 ， 她 的 丈夫 Bob 同 意 捐献 自己 的 一 个 此。 如 果 
Bob 的 肾 和 Alice 的 身体 相 容 ， 那 么 可 以 通过 手术 将 Bob 的 一 个 肾 摘 除 并 
移植 给 Alice。 


但 Bob 的 肯 有 可 能 受到 排斥 。 还 有 一 线 希 望 ， 就 是 所 谓 红 脏 交 换 项 目 。 
假如 男 一 个 人 Charlie 也 需要 肾 ， 愿 意 为 他 捐 肾 的 是 他 兄弟 David， 而 
David 的 肯 也 和 Charlie 不 相 容 。 然 和 而， 如果 David 的 绷 与 Alice 相 容 ， 并 且 
Bob 的 肾 和 Charlie 的 崩 相 容 ， 那 么 就 可 以 安排 让 四 人 同时 上 手术 台 ， 这 
样 术 后 每 个 人 都 有 一 个 好 肾 ， 挽 救 两 条 生命 。 


假设 我 们 有 了 关于 上 述 这 样 潜在 的 肾脏 捐献 者 -接受 者 的 数据 库 ， 就 可 



































通过 有 效 的 算法 ， 让 尺 可 能 多 的 两 对 捐献 者 -接受 者 成 功 配 对 ， 达 成 肾 
脏 交 换 。 基 本 上 这 束 是 前 一 章 介 绍 过 的 配对 问题 ， 很 容易 解决 。 


不 止 是 两 个 人 ， 还 可 以 有 更 多 人 来 配对 。2011 年 年 末 ，60 场 手术 为 30 位 
患者 移植 了 健康 的 肾 胜 ， 这 是 通过 其 他 任何 方法 都 不 可 能 做 到 的 。 


然而 如 果 人 允许 多 于 两 对 的 捐献 者 -接受 者 互 换 明 用， 如 何 找到 尽 可 能 
的 多 人 搭配 方案 在 目前 还 是 一 个 NP 完 全 问题 。P=NP 的 证 明 在 这 里 是 性 
命 侯 关 的 ， 可 比如 何 玩 好 扫雷 重要 得 多 。 























4.5 漏网 之 鱼 


人 们 在 20 世 纪 70 年 代 所 研究 的 大 部 分 NP 问 题 ， 都 要 么 被 认定 属于 NP 完 
全 问题 ， 要 么 被 有 效 解决 ， 从 而 归属 于 P。 但 还 是 有 一 些 NP 问 题 忌 顽 不 
灵 ， 难 以 确定 其 归属 。 这 些 问题 中 的 一 部 分 在 很 多 年 后 被 解决 了 ， 另 一 
部 分 直到 今天 都 还 没有 被 定性 ， 成 为 漏网 之 鱼 。 


1. 图 的 同 构 问题 


在 敌 友 国 流 行 着 一 个 叫 “ 思 剑 征程 ”(Blade Quest) 的 MMORPG (大 型 
多 人 在 线 角 色 扮 演 游戏 ) 。 游 戏 中 每 个 玩家 都 会 起 一 个 新 名 字 ， 操 纵 一 
个 虚拟 角色 〈avatar) 去 和 其 他 玩家 的 虚拟 角色 进行 互动 。 敌 友 国 的 敌 
友 关 系 也 被 引入 了 刀剑 征程 的 世界 。 在 现实 中 互 为 朋友 的 居民 ， 他 们 在 
游戏 中 的 虚拟 角色 也 是 朋友 关系 ; 相反， 现实 中 的 敌人 在 游戏 里 也 是 政 
人 。 


Isabel、John、Kevin、Laura、Molly 和 Nancy 是 几 个 喜欢 玩 思 剑 征程 的 敌 
友 国 居民 。 




















图 4-10” 玩 刀剑 征程 的 居民 


这 6 个 人 在 游戏 中 的 虚拟 角色 的 名 字 是 Achris、Bolem、Chyrard、 
Degarald、Enthrr 和 Fev， 但 是 哪个 虚拟 角色 对 应 哪个 真人 是 保密 的 。 在 
刀剑 征程 中 ， 这 几 个 虚拟 角色 也 有 一 个 好 友 关 系 图 。 





Achris 


Bolem Degarald 





Chryard Enthrr 


图 4-11 刀剑 征程 中 的 虚拟 角色 


Laura 看 了 这 两 张 峡 ， 就 在 游戏 里 给 别 的 玩家 发 了 一 个 消息 : “我 知道 你 
在 现实 中 是 谁 。” 你 能 猜 出 来 吗 ? 


这 两 张 图 存在 唯一 的 对 应 方式 ， 即 Isabelle 在 游戏 中 对 应 的 虚拟 角色 是 
Enthrr，John 是 Degarald，Kevin 古 Chryard，Laura 是 Bolem，Molly 是 
Achris， 还 有 Nancy 是 Fev。 我 们 可 以 验证 一 下 ， 如 Molly 在 敌 友 国 的 朋 
友 是 Laura 和 Nancy， 与 之 对 应 ， 在 刀剑 征程 中 Achris 的 朋友 是 Bolem 和 
Fev。 


好 友 关 系 图 之 间 的 映射 被 称 为 图 的 同 构 问题 。 有 可 能 存在 多 种 映射 ， 也 
可 能 不 存在 ， 这 取决 于 给 定 的 图 集 。 图 的 同 构 性 属于 NP 类 问题 ， 如 果 
知道 了 谁 对 应 谁 ， 你 可 以 通过 逐 对 但 看 好 友 关 系 在 两 张 图 中 是 否 一 致 来 
验证 这 个 解 的 有 效 性 。 


但 是 图 同 构 是 否 属于 P， 即 我 们 是 否 能 找到 图 之 间 的 映射 (假设 存在 》 
的 有 效 算法 ， 还 是 未 知 的 。 我 们 也 不 确定 图 同 构 是 NP 完全 的 ， 而 出 于 
多 种 搁 术 原因 ， 计 算 机 科学 家 也 不 认为 它 是 NP 完全 的 。 图 同 构 属于 为 
一 小 气 问 题 ， 其 难度 比 P 问 题 大 ， 但 比 不 上 哈密 顿 回路 、 最 大 制 等 NP 完 
全 问题 。 


2. 质数 和 因数 分 解 
你 可 以 对 15 进 行 因数 分 解 ， 得 出 15x1 或 5x3。24 这 个 数 可 等 于 24x1、 


12x2 、8x3 或 6x4。 但 是 你 只 能 把 17 写 作 17x1。17 是 一 个 质数 ， 即 只 能 
把 它 写 作 1 和 上 自身 乘积 的 数 。 最 开始 的 几 个 质数 是 2、3、5、7、11、 
































13、17、19。 质 数 有 无 限 多 个 。 已 知 的 最 大 质数 〈 在 我 写作 之 时 ) 是 一 
个 12 978 189 位 的 数 ， 它 开始 的 几 位 是 316 470 269 330 255 923 143 453 
pc : 


怎么 判断 一 个 数 是 否 是 质数 ? 例如 要 判断 1 123 467 619 是 否 是 质数 ， 你 
需要 遍历 所 有 小 于 1 123 467 619 的 数 ， 看 看 是 否 有 能 整除 它 的 数 。 事 实 
上 你 只 需要 检查 到 33 518 (1 123 467 619 的 平方 根 ) 就 可 以 了 。 听 起 来 
是 挺 快 ， 可 是 你 如 何 判 断 下 面 这 个 数 是 否 为 质数 ? 


8 273 820 869 309 776 799 973 961 823 304 474 636 656 020 157 784 206 
028 082 108 433 763 964 611 304 313 040 029 095 633 352 319 623 


早 在 古 和 希腊 就 出 现 了 判定 质数 的 算法 ， 但 直到 20 世 纪 70 年 代 才 出 现 对 几 
百 位 数 有 效 的 算法 。 这 些 算法 基于 数学 中 一 个 叫 数论 的 领域 的 研究 成 
果 ， 在 检查 时 需要 使 用 随机 生成 的 数 。 虽 然 这 些 算法 在 实践 中 表现 很 
好 ， 但 是 不 依赖 于 随机 生成 数 的 质数 判定 算法 直到 2002 年 ， 才 由 一 位 印 
度 教 授 曼 尼 达 : 阿 加 拉 瓦 尔 珊 领 他 的 学 生 尼 拉 吉 : 卡 亚 尔 和 尼 汀 : 萨克斯 
纳 发 现 ， 从 而 把 该 问题 归属 于 P 类 问题 。 


这 些 算 法 虽然 能 告诉 我 们 


8 273 820 869 309 776 799 973 961 823 304 474 636 656 020 157 784 206 
028 082 108 433 763 964 611 304 313 040 029 095 633 352 319 623 


这 个 数 不 是 质数 ， 但 令 人 惊奇 的 是 ， 它 们 不 能 告诉 你 这 个 数 的 因子 有 哪 
些 ， 也 就 是 说 不 能 对 其 因数 分 解 。 


我 们 有 判定 质数 的 有 效 算 法 ， 但 是 没有 分 解 因数 的 有 效 算法 。 


因数 分 解 是 一 个 NP 问 题 ， 因 为 如 果 你 看 到 了 

84 578 657 802 148 566 360 817 045 728 307 604 764 590 139 606 051 

和 

97 823 979 291 139 750 018 446 800 724 120 182 692 777 022 032 973 
这 两 个 数 ， 把 它们 相 乘 就 可 验证 乘积 等 于 上 面 的 

8 273 820 869 309 776 799 973 961 823 304 474 636 656 020 157 784 206 
028 082 108 433 763 964 611 304 313 040 029 095 633 352 319 623 




















计算 机 科学 家 认为 因数 分 解 不 属于 P 类 问题 ， 也 觉得 它 不 是 NP 完 全 问 
题 。 它 是 很 难 ， 但 不 像 可 满足 性 问题 或 地 图 填 色 问题 那样 难 。 


不 只 是 喜欢 摆弄 数字 的 数学 家 们 认为 质数 判定 和 因数 分 解 问 题 很 重要 。 
现代 密码 学 的 许多 方法 都 依赖 于 某 些 难以 分 解 因数 的 大 数 ， 这 是 第 8 章 


的 话题 。 
3. 线性 规划 


敌 友 国有 一 个 熟食 店 叫 Frenemy Fancy Franks， 里 面 出 售 四 种 口味 的 香 
肠 : 法 兰 殉 福 香 肠 、 意 大 利 香 肠 、 德 国 香肠 和 西班牙 香肠 。 不 同 种 类 的 
香肠 制作 时 间 不 同 ， 售 价 也 有 差别 。Frenemy Fancy Franks 应 该 如 何 安 
排 每 种 香肠 制作 的 数量 ， 以 获取 最 大 的 利润 呢 ? 


找到 最 优 的 方案 就 是 在 满足 各 种 限制 条 件 的 前 提 下 使 收入 最 大 化 。 假 设 
制作 一 根 法 兰 融 福 香肠 的 成 本 是 1 美元 ， 意 大 利 香肠 的 成 本 是 2 类 元 ， 德 
国 香肠 是 3 类 元 ， 西 班 牙 香肠 是 4 美元 ， 且 每 日 的 总 预算 是 1 万 美元 。 那 
么 ，1 乘 以 法 兰 克 福 香 肠 的 数量 ， 加 上 2 乘 以 意大利 香肠 的 数量 ， 加 上 3 
乘 以 德国 香肠 的 数量 ， 加 上 4 乘 以 西班牙 香肠 的 数量 ， 结 果 应 不 超过 1 
万 。 





























在 这 关 条 件 下 进行 最 优化 选择 的 问题 叫做 线性 规划 。 可 能 的 解 集 在 高 维 
空间 形成 一 个 几何 体 ， 叫 做 多 面体 。 


早 在 1947 年 ， 格 奥 尔 格 : 丹 齐 克 发 明了 单纯 形 法 (simplex method) ， 这 
种 方法 能 很 快 解 决 线性 规划 问题 。 单 纯 形 法 授 历 多 面体 所 有 的 边 ， 直 到 
找 出 最 佳 的 解 集 。 


既然 有 了 单纯 形 法 ， 我 为 什么 要 把 线性 规划 放 在 〈20 世 纪 70 年 代 ) 未 分 
类 的 问题 里 面 呢 ? 因为 在 茶 些 罕见 的 个 例 中 ， 单 纯 形 法 无 法 快速 求解 线 
性 规划 问题 。 


1979 年 ， 利 奥 尼 德 . 卡 奇 安 发 明了 李 球 算法 〈ellipsoid algorithm) ， 基 本 
思路 是 把 多 面体 切 分 成 越 来 越 小 的 块 ， 不 断 缩 小 范围 并 最 终 找到 最 优 
解 。 卡 奇 安 给 出 了 李 球 算法 有 效 性 的 证 明 ， 从 而 把 线性 规划 分 到 了 P 类 
问题 中 。 然 而 实践 中 覃 球 算法 的 耗 时 比 单纯 形 法 要 长 很 多 。 虽 然 缺乏 实 


用 性 ， 但 椭 球 算法 在 之 后 的 几 十 年 中 局 发 了 许多 更 复杂 的 算法 的 诞生 ， 
因而 它 在 学 术 上 还 是 很 有 影响 力 的 。 





图 4-12 多 面体 


这 样 一 来 ， 线 性 规划 在 理论 和 实践 上 分 别 都 有 了 好 的 解决 算法 
过 是 两 种 非常 不 同 的 算法 。 


1984 年 ， 纳 伦 德 拉 : 卡 马 卡 发 明了 内 点 算法 (interior point algorithm) 。 
和 单纯 形 法 类 似 ， 卡 马 卡 的 算法 过 历 多 面体 ， 只 不 过 是 在 内 部 遍历 而 不 
是 表面 。 和 椭 球 算法 一 样 ， 内 点 算法 也 能 将 线性 规划 归属 到 P 类 ， 并 且 
在 经 过 优化 后 该 算法 的 实际 性 能 甚至 高 于 单纯 形 法 。 


以 上 束 是 解决 线性 规划 问题 的 三 种 非常 不 同 的 算法 。 第 一 种 (单纯 形 ) 
在 实践 上 表现 很 好 。 第 二 种 〈 椭 球 ) 在 理论 上 很 好 。 而 第 三 种 (内 后 ) 
则 在 理论 和 实践 上 的 表现 都 很 好 。 能 对 一 个 在 20 世 纪 70 年 代 末 还 被 认为 
是 未 解决 的 问题 给 出 这 三 份 答案 ， 是 很 值得 人 们 为 之 日 聚 的 进步 。 


只 不 

















第 5 章 ”P 和 NP 诞生 前 的 历史 
不 要 怕 变 力 搜索 ， 而 是 要 合理 使 用 它 。! 


1 Georgy M. Adelson-Velsky Vladimir Arlazarov and Mikhail Donskoy Algorithms for Games 
(Programirovanie Igr) (New York: Springer-Verlag 1988). 


在 上 一 章 中 我 们 讲 到 了 高 德 纳 最 终 没 能 为 NP 完全 问题 找到 一 个 更 恰当 
的 英语 单词 。 如 果 他 当初 把 眼光 投 回 东方 的 俄罗斯 ， 就 会 发 现 一 个 合适 
的 词 perebor (IIepe6op) ， 意 为 “使 用 蛮 力 来 搜索 "， 即 尝试 所 有 可 能 性 
以 找到 最 佳 方案 。P/NP 问 题 其 实 是 在 问 ， 我 们 是 否 必须 用 蛮 力 搜索 来 解 
决 团 问题 ， 还 是 存在 更 快 的 方法 也 能 达到 目的 。 


但 是 当年 高 德 纳 和 其 他 美国 人 一 样 ， 都 很 难 了 解 俄罗斯 发 生 的 事情 。 从 
1945 年 第 二 次 世界 大 战 结束 起 ， 一 道 铁 幕 将 当时 的 苏联 与 东欧 ， 以 及 美 
国 与 西欧 隔绝 开 来 。 从 20 志 纪 50 年 代 开 始 ， 冷 战 导致 美国 和 苏联 两 国力 
绕 着 科技 发 展 展 开 了 一 系列 竞争 ， 两 国都 想 赢 得 这 场 知识 领域 的 “军备 
竞赛 ”。 由 此 带 来 的 一 个 负面 影响 是 基本 断绝 了 东西 方 科 学 界 的 互 访 和 
交流 。 尽 管 情况 在 20 世 纪 70 年 代 有 所 缓和 ， 但 直到 1991 年 冷战 结束 ， 东 
西方 才 恢 复 了 全 面 的 科研 交流 和 讨论 。 如 今 ， 随 着 大 部 分 的 学 术 成 果 都 
被 放 到 网 上 供 人 查阅 ， 再 加 上 学 者 可 以 较为 自由 地 到 世界 各 地 进行 学 术 
访问 ， 我 们 可 以 认为 全 球 同属 一 个 学 术 研 究 社 群 ， 而 不 是 被 人 为 地 分 成 
两 个 互 不 来 往 的 社 群 。 


这 一 章 讲述 了 两 个 故事 ， 两 条 通 往 P/NP 问 题 的 道路 。 结 局 是 西方 的 斯 带 
芬 ' 库 区 和 东方 的 列 昂 尼 德 : 莱 文 分 别 率 先 提 出 了 是 否 P=NP 的 问题 。 但 是 
科学 并 不 是 凭空 友 生 的 ， 两 边 的 科研 部 经 过 了 漫长 的 路 程 ， 最 终 才 可 能 
产生 库 殉 和 羔 文 的 工作 。 在 本 革 ， 我 们 会 截取 这 两 段 历史 的 几 个 片段 进 
行 讲述 ， 包 括 西 方 对 于 高 效能 计算 的 本 质 的 吾 百 探索 ， 以 及 东方 对 蛋 力 
搜索 的 必要 性 的 理解 。 最 终 我 们 会 发 现 二 者 殊途同归 ， 走 到 了 P/NP 问 题 
面前 。 














5.1 ”西方 


对 高 效能 算法 的 探索 可 追溯 到 大 约 3000 年 前 ， 人 类 第 一 次 使 用 基本 算术 
来 做 大 数 的 加 法 。 而 我 们 的 故事 从 20 世 纪 30 年 代 开 始 ， 当 时 人 们 开始 建 
芯 算 法 过 程 的 理论 。 


1. 呵 兰 . 图 灵 


我 们 为 探索 太空 而 发 明了 望 远 锐 ， 借 助 它 我 们 能 看 到 宇宙 遥远 的 地 方 ， 
了 解 它 早期 的 历史 。 我 们 建造 了 能 看 到 原子 的 显微镜 ， 也 建造 了 巨大 的 
机 需 用 以 击 雁 微 小 的 粒子 从 而 找到 更 小 的 粒子 。 我 们 甚至 破译 了 人 类 的 
DNA。 但 是 有 一 样 事物 ， 它 出 现在 我 们 的 果 上 、 和 车 内 ， 甚 至 口袋 里 ， 但 
我 们 仍然 觉得 它 很 神秘 ， 这 就 是 计算 机 。 计 算 机 到 底 是 什么 ? 


computer( 计 算 机 〉 这 个 词 早 在 17 世 纪 就 出 现 了 ， 那 时 还 没有 人 想象 过 
机 器 可 以 做 数学 运算 。 那 时 的 computer 是 计算 员 ， 即 做 计算 工作 的 人 。 
刚刚 兴起 的 银行 业 需 要 计算 员 来 记录 和 追踪 每 一 笔 存 款 和 借贷 的 账目 。 


根据 《牛津 英语 字典 》， 第 一 次 将 computer 用 于 指 代 能 计算 的 设备 是 在 
1897 年 ， 而 电子 计算 机 投入 使 用 是 在 20 世 纪 40 年 代 。computer 的 意义 ， 
从 一 种 人 变 为 几 台 庞大 的 机 器 ， 又 变 成 了 人 们 的 日 用 品 。 


不 要 把 计算 机 看 成 是 机 器 ， 想 想 它 的 功能 : 接收 信息 ， 根 据 指 令 处 理 信 
恩 ， 然 后 产生 输出 。 从 功能 角度 讲 ， 邮 政 服务 是 一 台 计 算 机 : 接收 信 
件 ， 解 码 地 址 ， 然 后 把 信件 分 发 投递 到 合适 的 位 置 。 生 物 学 过 程 也 是 一 
台 计 算 机 : 接收 DNA 序 列 ， 产 出 维持 生命 所 需 各 种 功能 的 蛋白 质 。 


而 我 们 称 之 为 计算 的 过 程 双 是 什么 呢 ? 有 没有 不 能 被 计算 的 事物 ? 这 个 
谜 题 在 电子 计算 机 问世 之 前 的 1936 年 ， 就 被 伟大 的 数学 家 阿兰 ' 图 灵 解 
开 了 。 图 灵 研 究 了 数学 家 的 思考 方式 ， 并 模拟 这 种 思维 过 程 发 明了 一 个 
形式 化 的 数学 模型 ， 我 们 现在 称 之 为 图 灵机 ， 已 成 为 计算 学 的 标准 模 


阿兰 :图 灵 1912 年 生 于 伦敦 。20 世 纪 30 年 代 初 ， 他 考 入 剑桥 大 学 国王 学 

















院 ， 展 露出 过 人 的 数学 才华 。 那 段 时 间 里 ， 他 从 一 个 数学 家 的 角度 ， 思 
考 了 计算 的 本 质 。 数 学 家 在 思考 时 有 一 定 的 方法 步 又， 尽管 人 的 记忆 容 
量 非 常 有 限 ， 但 是 记录 信息 的 纸 和 笔 则 可 以 敞开 供应 。 数 学 家 会 在 一 页 
纸 上 匆 匆 写 下 一 些 笔记 ， 写 完 一 张 纸 后 要 么 再 用 一 张 纸 ， 要 么 回 到 之 前 
写 过 的 某 张 纸 ， 对 笔记 进行 一 些 修改 。 图 灵 受 这 个 过 程 的 局 上 友 ， 创 造 了 
一 个 形式 化 的 计算 模型 ， 即 我 们 所 熟悉 的 图 灵机 。 
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图 5-1 图 灵机 


尽管 结构 非常 简单 ， 但 图 灵 宣 称 ， 他 的 机 塔 模型 可 计算 一 切 能 被 计算 的 

事物 。 几 乎 在 同一 时 间 ， 阿 降 佐 : 丘 奇 也 宣称 它 的 Lambda Calculus (和 演 

算 ， 一 种 原始 的 编程 语言 ) 能 做 同样 的 事情 。 丘 奇 -图 灵 论 题 虽 然 在 现 

代 计 算 机 发 明之 前 就 已 产生 ， 但 它 通过 了 时 间 的 考验 。 图 灵机 能 计算 现 

0 
灵机 。 


你 不 一 定 非 要 理解 图 灵机 的 工作 原理 才能 理解 计算 。 只 需要 想 想 任意 一 
种 编程 语言 ， 假 设 可 利用 的 存储 空间 是 无 限 的 。 所 有 编程 语言 在 功能 
征 等 效 的 ， 并 且 其 计算 能 力 都 等 于 简单 的 图 灵机 的 计算 能 


图 灵 在 1936 年 束 指 出 ， 图 灵机 并 不 是 什么 者 能 计算 。 最 着 名 的 例子 是 停 
机 问题 ， 即 没有 计算 机 能 通过 得 看 一 段 代码 就 知道 自己 是 会 永远 执行 下 
去 还 是 会 最 终 停止。 

在 第 二 次 世界 大 战 期 间 ， 图 灵 在 英国 的 密码 破译 工作 中 承担 了 重要 的 任 


务 。 战 后 ， 他 开始 考虑 图 灵机 是 否 是 以 人 脑 为 原型 的 。 他 引入 了 今天 我 
们 称 之 为 “图 灵 测 试 ” 的 判定 方法 ， 判 定 机 器 是 否 可 以 表现 出 类 人 的 智 


























能 。 假 设 你 通过 即时 通信 软件 和 别人 聊天 ， 你 能 判断 和 你 聊天 的 是 真人 
还 是 计算 机 程序 吗 ? 如 果 一 个 计算 机 能 让 大 部 分 人 误 以 为 它 是 真人 ， 它 
就 通过 了 图 灵 测 试 。 


不 幸 的 是 图 灵 的 学 术 生 涯 半路 天 折 。 他 于 1952 年 因 同 性 恋 行 为 被 当时 的 
英国 司法 机 关 判 定 有 罪 ， 这 最 终 导致 了 他 在 1954 年 自杀 。 直 到 2009 年 ， 
英国 首相 戈 登 :布朗 才 为 当年 政府 对 图 灵 的 判决 发 表 了 一 份 官方 道 菊 声 
明 。 


美国 计算 机 协会 以 图 灵 的 名 字 命名 了 计算 机 界 的 最 高 弯 誉 : 图 赤 奖 〈 等 
同 于 其 他 领域 的 话 贝 尔 奖 ) ， 以 表彰 网 灵 为 计算 机 科学 和 人 工 智能 所 做 
的 开创 性 工作 。 本 章 提 到 的 许多 科学 家 都 是 图 灵 交 得主。 


2. 计 算 复杂 上 度 


电子 计算 机 从 20 世 纪 50 年 代 开 始 在 社会 上 发 挥 重 要 作用 ， 人 们 需要 茶 种 
方法 来 衡量 要 解决 的 不 同 问题 的 计算 难度 。 第 一 批 方法 的 建立 源 于 科学 
家 对 人 类 思考 和 交流 方式 的 描述 。 


1943 年 ， 心 理学 家 浅 伦 : 麦 卡 洛克 和 添 尔 特 : 皮 次 建立 了 一 个 摘 述 脑 活动 
的 模型 ， 名 叫 神经 网 Cneural net) 。20 世 纪 50 年 代 ， 逻 辑 学 家 斯 蒂 芬 . 
克 莱 尼 建立 了 图 灵机 的 一 个 受 限 版 本 ， 叫 有 限 自 动机 (finite 
automaton) ， 并 研究 了 能 被 其 解决 的 问题 的 属性 。 有 限 上 自动 机 对 于 摘 
述 简 单机 器 《如 卖 汽 水 的 机 器 ) 的 控制 逻辑 非常 有 用 ， 但 过 多 的 限制 使 
它 无 法 表示 更 复杂 的 算法 。 


20 世 纪 50 年 代 ， 语 言 学 家 诡 姆 : 乔 姆 斯 基 试 图 理解 人 类 如 何 生成 英语 或 
其 他 语言 的 句子 。 他 引入 了 如 “上 下 文 无 关 文法 ”(context-free 
grammar) 等 方法 ， 可 生成 句子 的 解析 树 ， 如 下 图 所 示 。 





























Sentence (人 句子 ) 


Noun phrase (名 词性 短语 ) Verb phrase (动词 性 短语 ) 
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Article Adj.phrase Noun Verb Propositional phrase 
( 冠 词 ) (形容 词性 短语 ) (名 词 ) ” (动词 ) (介词 短语 ) 


Proposition Noun phrase (名 词性 短语 ) 
Adj. Adj. (介词 ) 
(形容 词 ) (形容 词 ) 
Article Ad Noun 
( 冠 词 ) (形容 词 ) (名 词 ) 
The quick brown fox jumped over the lazy dog. 
(敏捷 的 棕色 狐狸 跳 过 了 那 条 懒 洋洋 的 狗 ，) 








图 5-2 解析 树 


上 下 文 无 关 文 法 对 人 类 语言 句子 的 表述 有 一 定 合理 成 分 ， 但 不 够 完整 。 
目前 语言 学 界 对 哪 种 语法 更 适 于 表述 语言 一 一 抑或 这 种 语法 守 竟 存在 与 
个 还 存在 争议 。 


而 在 描述 和 解析 编程 语言 及 XML 等 计算 机 生成 的 数据 文件 等 方面 ， 上 
下 文 无 关 文 法 十 分 好 用 。 尽 管 如 此 ， 它 和 有 限 自动 机 一 样 ， 都 不 能 表述 
我 们 对 高 效能 计算 的 直观 概念 。 


人 们 还 引入 了 很 多 其 他 的 模型 ， 但 这 个 领域 的 突破 性 进展 发 生 在 1962 
年 ， 由 纽约 州 斯 克 内 克 塔 迪 通 用 电气 公司 科研 实验 室 的 尤 里 斯 : 哈 特 马 
尼斯 和 理 查 德 :斯 特 恩 斯 取得 。 他 们 想 出 一 种 绝妙 的 方式 ， 来 表示 计算 
机 程序 解决 问题 的 能 力 : 看 看 随 着 问题 描述 的 规模 的 扩大 ， 计 算 机 算法 
所 需 的 运行 时 间 和 存储 空间 发 生 了 多 大 的 变化 就 可 以 了 。 两 人 在 1965 年 
发 表 的 论文 《 论 算法 的 计算 复杂 度 》 (On the Computational Complexity 
of Algorithms) 推动 了 计算 复杂 度 这 个 研究 领域 的 诞生 。 因 为 这 些 工 
作 ， 哈 特 马 尼斯 和 斯 特 恩 斯 获得 了 1993 年 的 图 灵 奖 。 


20 世 纪 60 年 代 ， 计 算 复 杂 度 领域 出 现 了 两 个 不 同 的 研究 方向 。 其 中 一 个 
是 研究 在 给 定 的 时 间 、 存 储 空间 和 显 式 计算 模型 下 ， 哪 些 问题 能 够 被 解 
决 ， 而 哪些 不 能 。 力 一 个 研究 方 同 的 带 尖 人 是 曼 纽 尔 : 布 户 姆 ， 他 在 麻 












































省 理工 学 院 攻 读 博士 学 位 期 间 的 工作 采取 了 一 种 非常 抽象 的 方法 ， 其 研 
完结 果 不 仪 不 依赖 于 任何 特定 的 模型 ， 其 至 不 依赖 于 特定 种 类 的 资源 ， 
如 时 间或 存储 空间 。 这 两 种 方法 都 没有 抓 住 高 效能 计算 的 真正 本 质 。 


3.P 和 NP 


高 效能 计算 的 正确 定义 来 自 20 世 纪 60 年 代 的 两 骗 论文 ， 分别 是 杰 元 : 埃 
德 蒙 兹 的 “路 径 、 树 木 与 花灯 ”(Paths, Trees and Flowers) 和 艾 伦 : 科 巴 
姆 的 “函数 的 内 在 计算 难度 ”(The Intrinsic Computational Difficulty of 
Functions) 。 


埃 德 蒙 效 论文 最 重要 的 贡献 是 给 出 了 配对 问题 的 首 个 有 效 算法 ， 这 在 第 
3 半 讨 论 过 了 。 论 文 有 一 市 叫 “ 题 外 话 ”， 埃 德 蒙 兹 在 里 面 讨论 了 指数 和 
代数 级 别 的 区 别 ， 不 过 他 不 建议 为 算法 的 效率 设 定 任何 严格 的 标准 : 


需要 稍微 解释 一 下 用 到 的 “高 效能 算法 ”这 个 词 .…... 我 没有 准备 好 给 出 
严格 的 理论 体系 赋予 其 正式 的 含义 ， 况 且 这 篇 文章 的 上 下 文 也 不 适合 
这 样 做 ..….….. 实 践 中 ， 区 分 代数 级 别 和 指数 级 别 的 重要 性 ， 要 远大 于 区 
分 可 计算 与 不 可 计算 的 重要 性 .……… 如 果 硬 要 制定 一 些 严格 的 标准 ， 可 
能 会 在 实践 上 阻碍 有 用 的 算法 的 研发 ， 因 为 这 些 算 法 要 么 是 未 知 的 ， 
要 么 理论 上 与 标准 不 符 .…… 无 论 如 何 ， 为 鼓励 人 们 去 搜寻 优秀 而 实用 
的 算法 ， 很 重要 的 一 点 是 认识 到 : 质疑 此 种 标准 的 存在 价值 在 数学 上 
是 有 一 定 道 理 的 。 


埃 德 蒙 兹 的 “代数 级 别 * 正 是 P 所 代表 的 我 们 能 有 效 计算 的 问题 。 正 如 埃 
德 驼 效 建议 的 ， 虽 然 有 必要 用 正式 的 方法 来 定义 “是 否 P=NP” 等 问题 ， 
但 我 们 心中 也 应 该 对 高 效能 计算 有 一 种 非 正式 的 概念 ， 而 这 也 是 我 想 在 
本 书 中 表达 的 一 种 观点 。 


科 巴 姆 同样 独立 地 定义 了 P， 并 讨论 了 为 什么 这 个 概念 很 有 用 。 


有 很 多 原因 让 类 型 P 成 为 一 个 自然 而 然 的 概念 。 首 先 ， 如 果 我 们 对 各 种 
通用 类 型 的 计算 机 器 分 别 做 一 个 形式 化 的 表述 ， 会 发 现 总 是 离 不 开 几 个 
相同 的 定义 明确 的 函数 。 据 此 ， 我 们 能 给 出 一 个 数学 的 表征 P， 并 相信 
它 能 正确 地 表征 那些 定义 得 不 那么 正式 的 类 别 。 

















和 可 计算 性 的 定义 一 样 ， 类 型 P 并 不 依赖 于 计算 模型 的 特定 细节 。 
科 巴 姆 也 提醒 人 们 注意 : 


这 个 问题 让 人 想起 如 何 形式 化 地 定义 “效率 ”这 个 概 您。 虽然 二 者 很 明 
显 有 关联 ， 但 是 强调 的 方面 不 同 ， 这 里 主要 关注 的 是 计算 过 程 的 物理 
方面 。 


科 巴 姆 也 许 认 识 到 将 来 可 能 出 现 不 属于 他 所 说 的 类 型 P 的 计算 模型 。 随 
机 化 和 量子 计算 模型 的 研发 表明 ， 我 们 也 许 无 法 对 高 效能 计算 有 一 个 回 
定 的 概念 。 


之 后 在 1971 年 ， 斯 带 芬 库 殉 发 表 的 论文 定义 了 NP【〔 即 我 们 能 很 快 验 证 
的 问题 )、P/NP 问 题 ， 以 及 第 一 个 NP 完全 问题 。 一 年 后 理 查 德 : 卡 普 在 
论文 中 给 出 了 一 长 串 属于 NP 完全 的 问题 。 


1972 年 ，IBM 的 T.J. 华 生 研究 中 心 召开 了 一 次 有 关 计 算 机 的 计算 复杂 上 度 
的 座谈 会 ， 这 次 会 议 主要 因为 卡 普 的 论文 而 被 世人 记 住 。 组 织 者 在 会 议 
结束 时 安排 了 小 组 讨论 ， 探 讨 这 个 领域 的 未 来 发 展 。 其 中 一 个 问题 

是 : “如 何 把 原来 零散 的 下 确 界 结论 以 及 某 些 算法 整合 起 来 ， 发 展 成 一 
个 更 加 统一 的 理论 ? ”对 于 这 个 问题 的 答案 ， 包 括 卡 普 本 人 在 内 的 小 组 
成 员 都 没 太 有 把 握 ， 只 是 模糊 地 感觉 到 它 可 能 与 库 克 和 卡 普 的 论文 有 

关 ， 与 P、NP、 可 归 约 性 以 及 之 后 的 NP 完全 性 概念 等 有 关 。 


卡 普 意识 到 他 们 需要 为 这 个 新 领域 起 个 好 名 字 : 


“计算 复杂 度 ” 这 个 名 字 太 宽泛 了 ， 它 包括 了 布 卢 姆 和 其 他 人 的 工作 ， 
而 现在 我 们 还 没 法 把 他 们 的 工作 涵盖 进来 ; “混凝土 计算 复杂 上 度 " 听 起 
来 好 像 土 木工 程 的 分 支 !; “计算 机 计算 的 复杂 度 ”" 听 起 来 又 不 是 很 准 
确 。 

1 concrete 除 了 “实际 ”还 有 “混凝土 "的 意思 。 一 一 译 者 注 

后 来 这 个 领域 就 叫做 计算 复杂 度 。P/NP 问 题 的 重要 性 很 快 显现 ， 抢 尽 
了 这 个 领域 其 他 研究 方向 的 风头 。 抽 象 复 杂 度 给 人 的 感觉 更 不 靠 谱 了 。 


连 曼 纽 尔 : 布 卢 姆 本 人 也 改变 了 研究 方向 ， 开 始 转 攻 密 码 学 和 程序 检 
验 。 布 卢 姆 因 其 在 20 世 纪 60、70 和 80 年 代 所 做 的 广泛 研究 而 获得 1995 年 












































的 图 灵 奖 。 很 多 年 后 ， 当 被 问 及 他 在 20 世 纪 70 年 代 改 变 研究 方向 的 原因 
时 ， 布 户 姆 简单 地 答 道 :“ 库 殉 是 对 的 。” 





5.2 ”东方 


当年 苏联 的 “理论 控制 论 ?学 界 活 跃 着 很 多 重要 的 人 物 ， 而 我 们 的 故事 将 
集中 介绍 其 中 的 三 位 ， 他 们 分 别 代 表 处 理 蛋 力 搜索 的 三 种 方式 。 


1. 谢 尔 兰 ' 雅 布 隆 斯 基 ， 他 首次 将 蛮 力 搜索 的 研究 聚焦 于 寻找 实现 特 
定 计算 函数 的 最 小 电路 ， 但 他 的 权力 欲 和 做 慢 阻 但 了 俄罗斯 的 计算 
复杂 度 科学 的 发 展 。 

2. 安 德 烈 - 柯 尔 英 哥 洛 夫 ， 他 是 伟大 的 俄罗斯 数学 家 ， 主 张 通过 代数 
信息 来 衡量 复杂 度 。 

3. 柯 尔 英 哥 洛 夫 的 学 生 列 昂 尼 德 : 莱 文 ， 他 独 目 研究 发 现 了 P/NP 问 题 
和 NP 完全 问题 ， 但 是 由 于 政治 原因 ， 他 甚至 无 法 在 祖国 得 到 博士 


学 位 。 
1. 谢 尔 兰 ' 雅 布 隆 斯 基 


俄罗斯 的 计算 学 研究 被 称 为 理论 控制 论 ， 该 学 科 直 到 20 世 纪 50 年 代 电 子 
计算 机 在 军事 上 开始 发 挥 重要 作用 时 才 正 式 起 步 。 谢 尔 盖 . 弗 谢 沃 洛 多 
维 奇 ' 雅 布 隆 斯 基 生 于 1924 年 的 莫斯科 ， 二 战 时 兽 在 苏联 军队 服役 ， 戌 
后 到 莫斯科 国立 大 学 学 习 数学 。 他 于 1953 年 获得 博士 学 位 ， 导 师 是 俄 罗 
斯 可 计算 性 领域 的 先驱 彼得 ' 诡 维 科 夫 。 雅 布 隆 斯 基 和 话 维 科 夫 的 万 一 
个 学 生 阿 列 殉 谢 : 李 雅 普 话 夫 组 成 研究 小 组 ， 在 英 斯 科 国 立 大 学 举办 了 
一 系列 关于 逻辑 函数 的 研讨 会 。 他 们 的 小 组 成 了 俄罗斯 计算 理论 的 研究 
中 心 。 


第 4 章 提 到 的 可 满足 性 问题 的 处 理 对 象 是 由 基本 逻辑 运算 符 AND、OR 和 
NOT 组 合成 的 逻辑 表达 式 。 我 们 甚至 可 以 用 一 串 AND、OR 和 NOT 来 表达 计 
算 过 程 。 有 些 问 题 只 需要 少量 的 逻辑 运算 符 组 成 的 * 电 路 ”， 而 其 他 问题 
需要 大 规模 的 电路 才能 运算 。 谢 尔 盖 : 雅 布 隆 斯 基 在 20 世 纪 50 年 代 研 究 
了 这 个 概念 ， 我 们 今天 称 之 为 电路 复杂 性 。 


信息 论 创 始 人 ， 美 国人 殉 苑 德 香 农 证 明 茶 些 馆 辑 图 数 对 应 复杂 度 非 常 
高 的 电路 。 雅 布 隆 斯 基 则 研究 了 生成 这 些 函 数 的 实际 难度 。 听 起 来 是 个 
很 困难 的 任务 ， 但 实际 上 PzNP 的 一 个 强化 版 本 惑 意味 着 对 于 某 些 描述 























起 来 很 简单 的 搜索 问题 ， 不 存在 小 规模 的 电路 可 以 计算 它们 。 


雅 布 隆 斯 基 首 先 指 出 ， 根 据 香农 的 结论 ， 随 机 生成 的 函数 对 应 的 电路 的 
复杂 上 度 接 近 最 大 值 。 接 下 来 他 研究 了 如 何不 用 随机 过 程 就 能 找到 这 样 的 
函数 。 


需要 蛮 力 搜索 全 部 函数 吗 ? 他 证 明 任 何 能 生成 具有 接近 最 大 复杂 上 度 函 数 
的 过 程 ， 必 须 内 髋 所 有 函数 。 那 么 从 录 种 意义 上 讲 ， 任 何 能 生成 高 难度 
函数 的 过 程 都 能 经 过 修改 ， 以 生成 任意 其 他 的 函数 。 雅 布 隆 斯 基 提 出 ， 
这 意味 着 蛮 力 搜索 是 必要 的 ， 因 为 在 生成 高 难度 函数 的 过 程 中 ， 必 须 生 
成 每 一 个 可 能 的 函数 。1959 年 雅 布 隆 斯 基 将 他 的 论文 命名 为 “ 论 在 解决 
电路 理论 的 某 些 问题 时 不 可 能 排除 蛮 力 搜索 ”(《On the Impossibility of 

Eliminating Perebor in Solving Some Problems of Circuit Theory) 。 


雅 布 隆 斯 基 虽 然 证 明了 一 个 重要 的 结论 ， 但 他 的 解释 容易 误导 人 。 不 能 
根据 “从 一 个 高 难度 函数 能 生成 任意 函数 ”"， 就 推出 “生成 高 难度 函数 必 

须 生成 所 有 函数 "。 雅 布 隆 斯 基 的 结论 对 于 寻找 高 难度 函数 的 计算 复杂 
度 没 有 什么 实际 作用 。 雅 布 隆 斯 基 的 学 生 佐 拉 夫 勒 夫 在 1960 年 发 表 的 一 
篇 论文 标题 同样 令 人 印象 深刻 : “ 论 不 可 能 通过 采种 类 型 的 算法 构造 布 
尔 函 数 的 最 小 析 取 范式 ”(On the Impossibility of Constructing Minimal 

Disjunctive Normal Forms for Boolean Functions by Algorithms of a Certain 
Class) 。 这 篇 论文 同样 没有 谈 到 代数 运算 复杂 上 度 的 问题 。 这 些 研究 工作 
实际 上 和 P/NP 问 题 的 研究 没有 什么 关系 。 


当年 的 苏联 不 仅 在 经 济 上 集权 ， 在 学 术 活 动 上 也 是 如 此 。 雅 布 隆 斯 基 上 断 
定 他 目 己 的 研究 圆满 解决 了 灾 力 搜索 问题 ， 所 以 他 强力 压制 在 这 个 方 问 
上 的 进一步 研究 ， 特 别 是 对 计算 复杂 上 度 和 算法 的 研究 。 雅 布 隆 斯 基 后 来 
进入 了 苏联 协调 和 控制 数学 研究 的 数学 委员 会 ， 成 为 其 中 颇 有 影响 力 的 
成 员 ， 也 在 20 世 纪 60 年 代 造 成 了 不 少 的 和 争端， 后 面 将 会 讲 到 。 


2. 安 德 烈 ' 柯 尔 葛 哥 洛 夫 
安 德 烈 柯 尔 莫 哥 洛 夫 于 1903 年 出 生 在 俄罗斯 坦 波 夫 市 。1920 年 他 考 入 


莫斯科 国立 大 学 ， 最 开始 学 的 不 是 数学 ， 而 是 历史 学 。 他 研究 的 问题 
是 : 俄罗斯 在 中 世纪 的 征 税 工作 是 以 户 为 单位 还 是 以 村 为 单位 来 开展 

















的 。 他 分 析 了 税收 数据 ， 证 明 如 果 以 村 为 单位 来 收 税 ， 那 么 对 数据 的 描 
述 会 更 简单 一 些 。 他 把 这 些 结果 呈 交 到 有 历史 系 ， 得 到 了 极 大 的 赞扬 。 于 
是 他 询问 是 否 能 发 表 论文 ， 得 到 的 回答 却 是 :“ 你 只 有 一 个 证 据 。 在 历 
史 期 刊 上 发 表 文 章 至 少 需要 两 个 证 据 来 文 持 你 的 假说 。” 于 是 柯 尔 莫 哥 
洛 夫 放弃 历史 ， 转 而 研究 那些 一 个 证 据 就 足够 的 领域 。 柯 尔 莫 哥 洛 夫 选 
择 了 数学 ， 并 通过 努力 ， 成 为 20 世 纪 苏 联 乃 至 全 世界 最 伟大 的 数学 家 ， 
他 对 几乎 所 有 的 数学 领域 都 作出 了 基础 性 的 贡献 。 





? 问 
2 , :| 你 确定 生成 
看 ， 这 是 我 们 的 。 | | 的 是 随机 数 ? 确定 生成 他 


数 生成 器 ，。 





图 5-3 DILBERT © 2001 Scott Adams。 使 用 本 图 片 需要 得 到 
UNIVERSALUCLICK 的 许可 。 版 权 所 有 ， 侵 权 必 究 


柯 尔 砚 哥 洛 夫 对 理解 概率 和 随机 性 的 热忱 ， 直 接 促成 了 一 个 简单 却 伟大 
得 不 可 思议 的 想法 。 比 如 下 面 几 串 数字 : 


e 999 999 999 999 999 999 999 999 999 999 999 999 999 999 999 999 
999 

e。 707106781186547524400844362104849039284835937688474 

® 982 922 216 207 267 591 232 795 977 564 268 549 473 337 889 037 
097 


中 有 一 串 是 通过 随机 数 生成 器 生成 的 ， 其 他 两 串通 过 其 他 方法 生成 。 上 
面 每 个 数字 序列 发 生 的 可 能 性 都 是 相同 的 ， 为 什么 要 认为 一 个 序列 比 其 
他 序列 更 加 “随机 * 呢 ?在 继续 往 下 读 之 前 ， 请 大 家 先 猜 猜 哪 串 数字 真 的 
古 随机 生成 的 。 


很 难 认为 一 个 全 是 “9” 的 序列 是 随机 生成 的 。 第 二 个 序列 可 能 有 人 知道 
它 是 0.5 的 平方 根 小 数 点 后 数字 的 前 50 位 。 所 以 第 三 个 数 才 是 随机 选择 
的 。 











柯 尔 莫 哥 洛 夫 认 识 到 ， 一 个 序列 的 随机 性 大 小 可 以 通过 “最 少 需要 多 少 
字数 来 描述 它 ? 来 衡量 。 第 一 个 序列 的 描述 是 “50 个 9”。 第 二 个 序列 是 “1/ 
V2”。 而 对 于 第 三 个 数 ， 最 短 的 描述 只 能 是 982 922 216 207 267 591 232 
795 977 564 268 549 473 337 889 037 097。 “描述 ”是 一 个 不 正规 的 概念 ， 
柯 尔 莫 哥 洛 夫 通 过 计算 机 程序 的 表述 把 它 正 规 化 了 。 


类 似 的 想法 在 稍 早 也 先后 被 两 个 美国 人 提出 过 ， 他 们 分 别 是 雷 : 索 洛 莫 
诡 夫 《出 生 于 死 利夫 兰州 ， 厌 恶 目 己 的 俄罗斯 姓氏 ) 和 格 里 高 利 : 守 
廷 。 柯 尔 英 哥 洛 夫 及 其 第 子 则 深化 了 这 个 概念 ， 所 以 这 个 衡量 标准 被 称 
为 “ 柯 尔 英 哥 洛 夫 复 杂 度 ”。 


随机 序列 就 是 指 最 短 描述 是 本 里 的 序列 ， 比 如 
982 922 216 207 267 591 232 795 977 564 268 549 473 337 889 037 097 


通过 随机 选择 每 一 位 数 很 容易 就 能 生成 随机 序列 。 没 有 随机 数 就 没有 这 
些 随机 序列 。 不 存在 非 随机 化 的 算法 能 生成 任意 长 度 的 随机 序列 。 我 其 
至 不 知道 


982 922 216 207 267 591 232 795 977 564 268 549 473 337 889 037 097 
是 否 真 的 是 一 个 随机 序列 ， 因 为 必须 要 测试 所 有 比 它 短 的 描述 方式 ， 而 
有 些 表述 方式 可 能 非常 复杂 。 

柯 尔 莫 哥 洛 夫 复 杂 度 的 理论 背景 深厚 ， 并 且 在 机 器 学 习 、 算 法 分 析 和 计 
算 复杂 度 等 多 个 领域 有 广泛 应 用 。 虽 然 它 本 身 没 有 直接 涉及 P/NP 问 题 ， 


但 是 通过 对 它 的 研究 ， 柯 尔 划 哥 洛 夫 的 学 生 列 昂 尼 德 : 莱 文 直接 导出 了 
P/NP 问 题 。 





























3. 列 昂 尼 德 : 彝 文 


1961 年 ， 李 雅 普 库 夫 从 呐 斯 科 国 立 大 学 转 到 新 西伯 利 亚 国 立 大 学 任教 ， 
在 那里 他 建立 了 理论 控制 学 系 。 新 西伯 利 亚 市 距离 莫斯科 有 2800 公 里 之 
遥 ， 是 俄罗斯 第 三 大 城市 ， 也 是 西伯 利 亚 最 大 的 城市 。 


系 里 的 老师 大 部 分 是 雅 布 隆 斯 基 和 李 雅 普 诺 夫 以 前 的 学 生 ， 来 自 莫 斯 














科 。 新 组 建 的 理论 控制 学 系 很 快 成 为 俄罗斯 理论 控制 学 的 第 三 大 研究 中 
心 。 鲍 里 斯 - 特 拉 腾 布 罗 在 40 岁 就 已 经 是 这 个 领域 的 资深 研究 者 ， 他 在 
中 心 建成 之 时 就 已 加 入 ， 并 很 快 成 为 领军 人 物 。1962 年 ，Y. M. 巴 效 丁 
从 里 加 市 拉脱维亚 大 学 获得 博士 学 位 ， 并 加 入 了 新 西伯 利 亚 的 研究 中 

心 。 特 拉 腾 布 罗 开 始 和 巴 兹 丁 合作 ， 研 究 计 算 复 杂 度 的 基础 理论 ， 许 多 
拉脱维亚 和 新 西伯 利 亚 的 学 生 慕 名 而 来 。 在 20 世 纪 60 年 代 ， 他 们 开始 建 
立 一 个 复杂 度 的 算法 理论 ， 类 似 于 同时 期 西方 的 研究 。 


但 苏联 的 计算 复杂 上 度 理论 的 发 展 并 不 顺利 ， 正 如 特 拉 腾 布 多 1984 年 写 的 
那样 : 


我 们 与 “主流 ”的 控制 论 研 究 者 们 (主要 是 雅 布 隆 斯 基 ) 之 间 的 关系 恶 
化 了 ， 对 此 感到 担心 。 他 们 对 于 将 算法 理论 引入 复杂 度 研 究 领域 的 态 
度 十 分 消极 .…… 他 们 不 相信 计算 复杂 度 和 算法 复杂 上 度 在 蛮 力 搜索 领域 
起 到 的 作用 。 这 些 学 术 上 的 分 歧 很 可 能 因为 蛮 力 搜索 上 的 争议 而 加 

深 ,特别 是 当 雅 布 隆 斯 基 在 那样 一 个 协调 和 控制 数学 研究 的 组 织 中 担 
任 高 位 之 后 。! 














1* B.A. Trakhtenbort, “A Survey of Russian Approaches to Perebor Algorithms,” Annals of the 
History of Computing 6, no. 4 (October 1984). 


柯 尔 英 哥 洛 夫 于 1963 年 夏天 访问 了 新 西 们 利 亚 ， 他 和 特 拉 腾 布 多 分 享 了 
学 术 成 果 ， 探 讨 了 算法 理论 如 何 促进 对 信息 和 复杂 上 度 的 理解 。 


在 那 次 访问 之 后 ， 柯 尔 莫 哥 洛 夫 很 快 到 了 基辅 大 学 ， 并 访问 了 一 个 为 数 
学 和 物理 学 神童 专 设 的 高 中 寄宿 学 校 。 他 随便 问 了 几 个 问题 ， 很 多 问题 
都 被 一 个 叫 列 昂 尼 德 : 莱 文 的 15 尹 孩子 解答 了 。 柯 尔 葛 哥 洛 夫 后 来 洲 请 
莱 文 到 莫斯科 大 学 跟 他 学 习 。 莱 文 在 研究 生 期 间 的 杰出 工作 分 为 两 个 方 
问 。 


首先 ， 羔 文 太 明 了 一 个 通用 的 搜索 算法 。 假 设 Alice 对 Bob 说 她 有 能 快速 
求解 团 问题 的 算法 ， 但 是 不 告诉 Bob 是 什么 算法 。 莱 文 的 技巧 能 让 Bob 
创造 出 一 个 几乎 和 Alice 的 算法 一 样 快 的 算法 ， 而 他 不 需要 知道 Alice 的 
算法 具体 是 什么 。 莱 文通 过 柯 尔 莫 哥 洛 夫 复 杂 度 的 一 个 变种 发 展 了 自己 
的 理论 ， 基 本 上 是 尝试 了 所 有 合理 的 方式 ， 才 取得 了 这 个 成 果 。 


对 搜索 的 研究 使 菜 文 转 而 思考 那些 能 反映 搜索 本 质 的 问题 ， 于 是 他 引入 


























了 “通用 搜索 问题 ”的 概念 ， 这 个 概念 基本 相当 于 库 殉 提出 的 NP 完全 性 。 
羔 文 列 出 了 6 个 通用 搜索 问题 ， 其 中 就 包括 可 满足 性 问题 ， 从 而 正式 建 
立 了 P/NP 问 题 。 


在 莱 文 取得 的 这 两 项 令 人 惊叹 的 成 就 中 ， 仅 第 二 项 几乎 就 可 以 跟 为 库 克 
最 得 图 灵 奖 的 那 篇 论文 妮 美 。 然 而 柯 尔 英 哥 洛 夫 却 认为 两 个 结果 无 法 分 
开发 表 ， 于 是 他 强迫 莱 文 把 它们 写 在 一 篇 论文 里 。 当 时 俄罗斯 的 数学 出 
版 物 的 风格 导致 精简 的 论文 更 受 欢迎 ， 文 中 基本 不 会 给 出 支持 结论 的 证 
据 的 细节 。 羔 文 把 这 种 风格 发 挥 到 了 极致， 将 两 项 成 采写 在 了 一 访 只 有 
两 页 的 论文 里 。 


沫 文 在 苏联 申请 博士 学 位 的 时 候 ， 没 有 把 这 篇 杰作 包括 在 论文 集 里 。 当 
时 所 有 苏联 年 轻 人 都 是 苏联 共产 主义 青年 团团 员 。 沫 文 经 常 在 共青团 的 
活动 中 调皮 的 重 ， 他 低估 了 这 些 行为 的 后 琳 。 这 些 行为 最 终 导致 他 没有 
被 授予 博士 学 位 ， 因 为 政治 不 合格 。 


莱 文 在 苏联 无 法 摆脱 政治 问题 的 纠缠 ， 他 想方设法 在 1978 年 移民 到 了 美 
国 。 艾 伯 特 : 梅 耶 将 他 录取 为 及 省 理工 学 院 的 研究 生 ， 由 于 他 以 前 的 研 
完工 作 太 厉害 ， 第 二 年 就 拿 到 了 博士 学 位 。 后 来 莱 文 到 波士顿 大 学 担任 
教授 ， 直 到 今天 。 


莱 文 的 工作 在 20 世 纪 70 年 代 中 期 才 被 美国 所 知晓 ， 那 时 P/NP 问 题 已 经 广 
受 关注 。 莱 文 没 能 分 享 库 克 1982 年 的 图 灵 奖 ， 而 直到 20 世 纪 80 年 代 末 
期 ， 人 们 才 把 NP 完 全 性 的 早期 结果 称 为 库 克 - 莱 文 定理 。 


20 世 纪 80 年 代 后 ， 苏 联 与 美国 的 关系 开始 缓和 。 一 名 俄罗斯 学 生 亚 历 山 
大 : 拉 效 波 洛 夫 为 一 种 通过 电路 复杂 上 度 理论 来 证 明 PxNP 的 方法 做 出 了 重 
要 页 献 ， 这 个 故事 我 们 留 到 第 7 章 再 讲 。 


随 痢 苏联 的 解体 和 互联 网 的 崛起 ， 俄 罗斯 数学 研究 者 的 工作 不 再 与 世 陋 
绝 。 计 算 复杂 度 领 域 真正 成 为 全 球 性 的 研究 课题 。 



































5.3 哥 德 尔 的 信 


1956 年 ， 库 尔 特 :可 德尔 写 信 给 约翰 : 冯 : 诺 依 曼 ， 后 者 是 计算 机 科学 和 其 
他 许多 领域 的 先驱 。 在 这 封 (用 德语 写 的 ) 信里 ， 哥 德尔 讨论 了 可 满足 
性 问题 ， 并 用 一 种 不 同 的 术语 规范 化 了 P/NP 问 题 。 他 提出 如 果 我 们 生活 
在 P=NP 的 世界 里 ， 那 么 “数学 家 思考 ‘是 或 否 ' 的 思想 工作 将 完全 由 机 器 
来 代替 ..….. 而 我 个 人 认为 ， 这 完全 是 有 可 能 发 生 的 >”。 这 封 信 的 写作 时 
间 比 库 克 和 羔 文 的 论文 发 表 早 15 年 。 


我 们 不 知道 冯 : 话 依 曼 是 否 回 复 了 这 封 信 ， 其 至 不 知道 他 是 否 看 到 了 
它 。 汉 : 诺 依 受 那 时 已 经 身 患 癌症 ， 不 久 就 于 1957 年 酬 世 。 这 封 信 则 直 
到 20 世 纪 80 年 代 才 为 科学 界 所 知 。 哥 德尔 在 1978 年 去 世 ， 然 而 他 晚年 已 
经 神志 不 清 ， 无 法 注意 到 库 克 只 是 重 述 了 他 提出 的 问题 。 


既然 是 哥 德 尔 早 于 库 元 和 羔 文 发 现 了 P/NP 问 题 ， 为 什么 我 们 不 把 P=NP 
称 为 “ 哥 德 尔 问题 >?， 以 肯定 他 的 贡献 呢 ? 因为 科学 领域 遵循 的 是 哥伦布 
原理 : 哥伦布 出 名 并 不 是 因为 他 第 一 个 发 现 了 美洲 ， 而 是 因为 他 最 后 一 
个 发 现 了 美洲 。 哥 德尔 本 人 也 不 是 没有 问题 。 他 上 自己 都 没有 意识 到 当年 
向 汉 : 诺 依 曼 提 出 的 这 个 问题 的 重要 性 ， 不 然 他 不 会 在 之 后 的 任何 一 个 
公开 场合 都 没有 提出 这 个 问题 。 库 元 和 羔 文 仍然 是 率先 发 表 论 文 ， 并 癌 
学 术 界 呈现 P/NP 问 题 的 人 。 


为 纪念 哥 德 尔 为 逻辑 学 作出 的 黄 基 性 贡献 以 及 哥 德 尔 的 这 封 重要 信件 ， 
理论 计算 机 科学 界 于 1993 年 设立 了 哥 德 尔 奖 ， 表 彩 该 领域 近期 发 表 的 态 
出 研究 论文 。 



































5.4 ”火星 人 法 则 


我 们 怎么 判断 一 个 科学 理念 是 目 然 产生 的 《就 如 同 造物 主创 造 的 一 
样 ) ， 还 是 由 人 类 的 主观 活动 产生 的 呢 ? 假设 我 们 发 现存 在 火星 文明 ， 
其 科技 水 平 与 我 们 地 球 文 明 的 水 平 相当 。 如 果 在 火星 文明 中 有 一 个 与 地 
球 文明 相同 或 相近 的 理念 ， 那 么 这 个 理念 应 该 是 目 然 产生 的 ， 因 为 它 分 
别 来 源 于 两 个 独立 的 文明 。 


当然 不 存在 火星 文明 来 和 地 球 文明 做 比较 ， 所 以 只 能 想象 一 下 。 假 设 火 
星人 的 计算 机 器 叫 Exigius ， 它 和 图 灵机 有 本 质 的 区 别 ， 但 是 两 者 有 着 
相同 的 计算 能 力 。 那 么 火星 版 的 丘 奇 -图 灵 论 题 是 : 一 切 可 计算 的 事物 
都 能 被 Exigius 计 算 。 所 以 从 火星 人 的 角度 看 ， 图 元 机 不 是 自然 产 生 的 ， 
而 计算 这 个 概念 是 目 然 产生 的 。 


1 Exigius 这 个 名 字 来 自 美国 科幻 电视 连续 剧 My Favorite Martian， 中 文 译 为 《火星 叔 叔 马丁 》。 
译 者 注 



























































对 于 P/NP 问 题 的 自然 性 ， 我 们 不 需要 火星 人 来 证 明 。 当 年 苏联 和 北美 的 
研究 者 在 役 此 隔绝 的 情况 下 ， 发 现 了 同一 个 PINP 问 题 以 及 NP 完 全 问 
题 。 他 们 的 研究 动机 不 同 : 在 东方 ， 人 们 试图 理解 蛮 力 搜索 的 必要 性 ; 
而 在 西方 ， 人 们 则 希望 理解 高 效能 计算 的 力量 。 他 们 沿 着 各 目的 研究 之 
nn 
登 的 地 方 。 


类 似 地 ， 假 想 中 的 火星 人 应 该 也 会 发 现 P/NP 问 题 (或 者 类 似 的 问题 ， 但 
愿 他 们 还 没有 先 我 们 一 步 解 决 这 个 问题 ， 并 且 很 可 能 他 们 也 认为 这 个 
问题 是 自然 产生 的 ， 而 且 非 常 重要 。 


第 6 音 ”处理 困难 的 问题 


在 第 2 章 ， 我 们 看 到 了 P=NP 的 美好 世界 。 生 活 将 如 此 轻松 ， 人 们 可 以 对 
一 切 进 行 最 优化 ， 了 解 万 事 万 物 。 我 们 将 拥有 让 人 心 想 事 成 的 机 器 。 这 
一 切 太 过 美好 了 ， 以 至 于 有 点 吓人 人， 而且 几乎 肯定 是 不 切实 际 的 约 想 。 


我 们 更 可 能 生活 在 一 个 相对 混乱 的 世界 ， 一 个 PzNP 的 “不 优雅 的 世 
界 。 即 使 P=NP， 在 找到 解决 NP 问题 的 算法 之 前 ， 我 们 还 是 一 样 生活 在 
PzNP 的 世界 。 那 么 对 于 那些 我 们 不 能 有 效 求解 的 问题 ， 我 们 该 怎么 处 
理 ? 直接 放弃 吗 ? 


有 时 候 我 们 不 得 不 处 理 困难 的 问题 。 哈 利 在 Acme 制 造 广 担 任 主 调度 
师 。 老 板 艾 米 让 哈 利 安排 机 器 的 调度 方案 ， 来 生产 Acme 最 新 的 手机 A- 
Phone， 并 要 求 使 用 的 时 间 尽 可 能 短 。 哈 利 读 了 本 书 开 头 的 几 章 然后 回 
答 :“ 对 不 起 ， 但 那个 问题 是 NP 完全 的 。 连 很 多 著名 的 计算 机 科学 家 者 
不 相信 这 类 问题 存在 有 效 的 解决 方法 ， 所 以 我 试 也 是 白 试 。 我 还 是 去 打 
保龄球 吧 。” 艾 米 和 直接 祝 哈 利 玩 得 开心 ， 然 后 不 用 来 上 班 了 。 


艾 米 很 快 提拔 了 乔治 来 代 符 哈 利 。 笠 好 乔治 该 了 本 书 的 这 一 章 ， 然 后 拟 
出 了 一 个 生产 A-Phone 的 调度 方案 。 乔 治 写 出 了 一 个 总 能 找到 最 好 的 调 
度 方 案 的 美妙 算法 吗 ? 没有 。 但 是 乔治 有 没有 把 事 做 完 ?是 的 。 


NP 完 全 问题 是 难以 驯服 的 野兽 ， 如 果 有 Pz<NP， 那 我 们 不 可 能 找到 一 个 
能 对 所 有 问题 总 给 出 最 好 方案 的 快速 算法 。 然 而 我 们 不 必 放 弃 ， 本 章 我 
们 就 来 看 看 有 哪些 方法 能 在 处 理 困 难 问题 时 派 上 用 场 。 


对 于 中 等 规模 的 问题 ， 我 们 可 以 用 如 今 非 第 快 的 计算 机 遍历 所 有 的 解决 
方 采 。 我 们 可 以 采用 一 些 虽 然 不 能 包 治 百 病 ， 但 对 我 们 关心 的 问题 起 作 
用 的 算法 。 还 有 的 算法 虽然 不 能 给 出 所 有 可 能 方案 中 最 好 的 ， 但 是 能 给 
出 一 个 足够 好 的 方案 。 


有 的 时 候 你 想 尽 办 法 也 找 不 到 一 个 NP 完 全 问题 的 解决 方法 。 你 可 以 试 
着 解决 一 个 不 同 的 问题 ， 或 者 干脆 放弃 。 天 涯 何 处 无 芳 草 ， 何 必 在 一 棵 
树 上 吊 死 。 




















6.1 畜 力 


计算 机 很 快 ， 其 至 是 你 保 上 或 口袋 里 的 那些 计算 机 ， 也 快 到 不 可 思议 ， 
以 至 于 它们 可 以 通过 使 用 “ 番 力 ”搜索 所 有 可 能 的 方 采 ， 来 解决 一 个 中 等 
规模 的 问题 。 


以 前 可 不 是 这 样 的 。 在 斯 带 芬 : 库 元 将 P/NP 问 题 呈献 给 世人 的 1971 年 ， 
英特尔 公司 发 布 了 它 的 第 一 个 微 处 理 器 忆 Intel 4004。Intel 4004 是 
第 一 个 包含 整个 CPU 的 必 片 ， 也 是 第 一 个 商业 化 的 微 处 理 器 。Intel 4004 
当时 的 运行 速度 是 每 秒 执行 92 000 条 指令 。 


以 库 克 的 可 满足 性 问题 为 例 ， 设 共有 20 个 变量 ， 考 虑 一 个 简单 的 算法 ， 
它 会 过 历 并 尝试 所 有 让 每 个 变量 分 别 为 TRUE 或 FALSE 的 解 集 。 如 果 验 
证 每 个 解 需要 100 步 ， 那 么 我 们 可 以 在 19 分 钟 内 判断 某 个 表达 式 是 否 能 
被 满足 。 这 个 时 间 不 是 特别 长 ， 毕 竟 用 20 个 变量 表示 不 了 多 少 内 容 。 


解决 一 个 25 个 变量 的 问题 需 花 费 10 小 时 ， 而 求解 30 个 变量 的 问题 将 超过 
13 天 。 一 个 40 个 变量 的 问题 ， 如 果 按 1971 年 的 计算 能 力 ， 将 算 到 2009 
全 


























这 段 时 间 里 ， 英 特 尔 每 年 都 会 发 布 很 多 型 号 的 处 理 嚣 。 让 我 们 从 2009 年 
选 一 个 型 号 ，Intel i7-870， 它 每 秒 执行 的 指令 数 是 29.3 亿 条 (是 Intel 
4004 的 3 万 多 倍 ) 。 用 这 个 速度 ， 求 解 40 个 变量 的 问题 将 花 避 大 概 10 个 
小 时 。 也 就 是 说 ， 如 果 你 在 1971 年 想 求解 一 个 40 个 变量 的 问题 ， 你 可 以 
选择 花 38 年 玩 自己 的 手指 ， 然 后 用 2009 年 的 科技 解决 这 个 问题 ， 这 比 从 
1971 年 就 开始 用 当时 的 科技 来 计算 还 要 快 。 


针对 某 些 其 他 的 NP 问 题 ， 算 例 的 规模 可 以 更 大 。NP 完 全 的 旅行 推销 员 
问题 是 指 找到 访问 许多 个 城市 的 最 短路 线 。 用 所 谓 的 分 割 面 法 ， 我 们 可 
以 用 很 短 时 间 解 决 1 万 个 城市 规模 的 旅行 推销 员 问 题 。 美 国人 口 超过 500 
的 城市 共有 13 509 个 ， 图 6-1 是 穿 过 这 些 城市 的 最 短路 径 。 





图 6-1 500 人 以 上 城市 的 旅行 推销 员 问 题 


对 于 其 他 的 NP 问题 ， 可 能 性 的 数目 大 到 连 解 决 中 等 规模 的 问题 都 不 太 
可 能 。 


虽然 我 们 即将 逼近 计算 机 速度 的 物理 极限 ， 但 随 着 摩尔 定律 反映 出 的 忆 
片上 核心 处 理 器 个 数 的 快速 增长 ， 人 们 仍然 期 望 计算 机 的 运算 能 力 持续 
出 现 戏剧 性 的 增长 。 这 将 有 助 于 未 来 更 大 规模 的 NP 完 全 问题 得 到 解 
决 。 然 而 问题 的 复杂 上 度 也 会 随 着 规模 的 扩大 迅速 增长 。 所 以 别 指望 能 在 
近期 解决 150 个 变量 的 可 满足 性 问题 ， 或 是 找到 2 万 个 城市 之 间 的 最 佳 旅 
行 方 案 。 














6.2 启发 式 方法 


17 世 纪 的 伐木 工 在 测量 中 经 常用 他 们 拇指 的 长 度 来 大 致 度量 1“ 英 寸 "的 
距离 。“ 拇 指 规则 ”这 一 俗语 可 能 就 源 自 于 此 ， 意 思 是 在 决定 某 些 问题 答 
案 的 过 程 中 使 用 一 种 不 太 准确 但 大 致 可 用 的 简化 方法 。 谚 语 “ 朝 起 不 出 
门 ， 晚 霞 行 千里 "给 出 了 一 种 粗略 但 通常 相当 可 靠 的 预测 天 气 的 方式 。 

摩尔 定律 本 身 也 提供 了 一 种 粗略 地 预测 未 来 计算 机 的 计算 能 力 的 方法 。 


计算 机 算法 同样 也 是 一 种 过 程 。 局 发 式 方法 是 一 种 原理 类 似 “ 拇 指 规 
则 ”的 算法 ， 虽 然 不 能 保证 给 出 正确 的 答案 ， 但 可 以 对 大 多 数 你 想 解 决 
的 问题 给 出 答案 。 人 们 在 认识 到 某 些 问题 是 NP 完 全 问题 之 前 ， 丈 给 出 
了 它们 的 局 发 式 解法 。 几 十 年 来 ， 我 们 为 解决 各 种 困难 的 问题 及 明 了 很 
多 复杂 的 局 发 式 方法 。 虽 然 这 些 方法 不 适用 于 任意 一 个 NP 完 全 问题 的 
所 有 人 情况， 但 有 助 于 根据 特定 的 情况 解决 人 们 所 面临 的 部 分 问题 。 


让 我 们 来 详细 分 析 一 个 地 图 填 色 问题 的 简单 而 强大 的 启发 式 方法 。 在 第 
3 章 我 们 证 明了 为 美国 地 图 填 色 人 至少 需要 4 种 颜色 ， 才 能 保证 所 有 接壤 的 
州 有 具有 不 同 的 颜色 。 


加 利 福 尼 亚 、 俄 勒 由 、 爱 达 和 荷 、 狂 他、 亚利桑那 这 几 个 州 围绕 着 内 华 达 
州 成 为 一 圈 。 至 少 需 要 三 种 颜色 为 加 利 福 尼 亚 、 俄 勒 闪 、 爱 达 荷 、 犹 
他 、 亚 利 桑 那 这 几 个 州 填 色 。 而 内 华 达 州 并 非 个 例 。 肯 塔 基 州 周围 围 绕 
着 田 纳西 、 弗 吉 尼 亚 、 西 弗吉尼亚 、 俄 雍 俄 、 印 第 安 纳 、 伊 利 话 伊 和 密 
苏 里 这 几 个 州 。 同 样 ， 你 需要 至 少 3 种 颜色 填充 这 几 个 围 成 一 圈 的 州 ， 
再 用 第 4 种 颜色 填充 肯塔基 州 。 



































图 6-2 美国 地 图 


一 张 地 图 只 要 上 面 的 条 个 地 区 被 奇数 个 相 邻 的 地 区 所 环绕 ， 那 么 它 最 少 
需要 4 种 颜色 。 


这 里 有 一 张 亚 美 尼 亚 各 州 的 地 图 。 


阿塞拜疆 飞 地 







格 加 尔 库 尼克 州 


阿塞拜疆 飞 地 


图 6-3 ”亚美尼亚 


只 有 两 个 州 完全 在 亚美尼亚 内 部 ， 不 与 其 他 国家 接壤 。 科 泰克 州 
(Kotayk') 有 6 个 邻 州 ， 而 首都 埃 里 温 〈Yerevan) 有 4 个 邻 州 。 每 个 不 
靠 海 的 省 都 有 奇数 个 邻 州 。 所 以 启发 式 方法 告诉 我 们 ， 也 许 能 用 3 种 方 
法 为 这 张 地 图 填 色 。 事 实 上 真 的 可 以 。 





阿塞拜疆 飞 地 






阿塞拜疆 飞 地 


图 6-4 填 色 后 的 亚美尼亚 地 图 


瑞士 有 5 个 邻 国 : 法国、 意大利、 奥地利、 列支敦士登 和 德国 。 昌 然 邻 
国 数 为 5， 我 们 还 是 可 以 用 3 种 颜色 填充 这 张 地 图 。 
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图 6-5 “瑞士 
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图 6-6 ” 填 色 后 的 瑞士 地 图 


列支敦士登 将 瑞士 和 奥地利 的 国境 线 分 割 为 两 段 ， 所 以 对 于 地 图 填 色 这 
个 问题 ， 我 们 需要 把 奥地利 算 两 次 。 重 要 的 不 是 邻 国 的 数量 ， 而 是 国境 
线 的 数量 。 瑞 士 有 6 段 国境 线 ，6 是 偶数 。 而 且 只 有 外 围 的 国境 线 才 算 


数 ， 对 于 那些 完全 位 于 其 他 国家 领土 内 部 的 国家 (如 意大利 内 部 的 焚 带 
中)〉， 我 们 不 把 它们 的 国境 线 计 算 在 内 。 


如 果 这 个 启发 式 方法 总 能 给 出 正确 的 答案 ， 那 么 它 将 是 一 个 解决 NP 完 

全 的 三 色 填 充 地 图 问题 的 有 效 算法 ， 进 而 我 们 就 有 了 解决 所 有 NP 问 是 

的 有 效 算 法 ， 即 P=NP。 读 到 这 里 你 可 能 猜 到 了 ， 这 个 启发 式 方法 不 总 

是 有 效 。 

令 这 个 启发 式 方法 失效 的 反例 有 两 个 。 

1. 地 图 上 有 一 个 湖 将 两 个 地 区 分 隔 开 来 ， 如 密 持 根 湖 将 伊利 诺 伊 州 和 
密歇根 州 分 隔 开 来 。 

2. 地 图 上 有 4 个 以 上 的 地 区 汇聚 于 同一 点 ， 如 亚利桑那 、 新 墨西哥 、 
科罗拉多 和 犹他 这 四 个 州 。 

在 填充 美国 地 图 时 这 些 反例 不 重要 ， 因 为 我 们 已 经 知道 填充 美国 地 图 至 

少 要 4 种 颜色 ， 这 甚至 没有 把 填充 湖面 的 蓝 色 计算 在 内 。 


然而 这 个 局 发 式 方法 在 现实 世界 中 很 少 失效 。 为 说 明 问 题 ， 让 我 们 来 看 
看 虚构 的 政 友 国 地 图 。 虽 然 每 个 省 都 有 偶数 个 邻 省 ， 但 还 是 不 能 只 用 3 
种 颜色 为 敌 友 国 地 图 填 色 不 包括 湖面 的 更 色 〉， 以 确保 两 个 接壤 的 省 
的 颜色 不 同 。 
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图 6-7 敌 友 国 地 图 


每 个 省 都 和 4 个 其 他 的 省 接壤 。 没 有 一 个 省 被 邻 省 围绕 成 环 ， 因 为 有 湖 
水 从 中 阻隔 。 启 发 式 方法 告诉 我 们 可 以 只 用 3 种 颜色 填充 这 11 个 省 ， 但 
实际 上 这 不 可 能 ， 只 用 三 色 必然 导致 邻 省 同色 的 情况 。 启 发 式 方法 在 敌 
友 国 能 否 用 三 色 填 充 地 图 的 问题 中 给 出 了 错误 的 答案 。 


可 满足 性 理论 及 其 应 用 国际 学 术 年 会 〈The International Conference on 
Theory and Applications of Satisfiability Testing) 是 可 满足 性 问题 相关 领 
域 研 究 人 士 的 一 个 交流 和 展示 的 平台 ， 尤 其 重视 优秀 的 启发 式 方法 。 会 
议 组 织 了 SAT1 竞 赛 ， 比 拼 各 种 计算 机 算法 求解 可 满足 性 问题 的 能 
竞赛 用 的 可 满足 性 问题 有 的 是 随机 生成 的 ， 有 的 是 特意 构造 出 来 以 提高 
难度 的 ， 还 有 的 则 是 实际 应 用 中 产生 的 。 这 些 算法 中 有 许多 都 能 解决 某 
些 达 到 一 百 万 个 变量 规模 的 可 满足 性 问题 。 


1 SAT 为 可 满足 性 问题 (satisfiability〉 的 前 三 个 字母 。 一 一 译 者 注 
启发 式 方法 并 不 总 能 奏效 。 没 人 能 在 SAT 竞 赛 中 取得 完美 的 成 绩 。 但 通 


种 来 讲 ， 对 各 种 计算 技巧 的 巧妙 使 用 ， 再 加 上 当今 最 快 的 机 器 的 强劲 火 
力 文 援 ， 有 些 算法 甚 全 能 求解 规模 很 大 的 最 优化 问题 。 
































6.3 ”搜索 小 规模 的 解 


如 果 我 们 想 在 敌 友 国 的 2 万 居民 中 寻找 数目 为 3 的 团 ， 最 原始 的 方法 需要 
检查 1 万 亿 多 一 点 种 可 能 ， 这 对 如 今 的 计算 机 不 太 困 难 。 但 是 数目 增长 
得 太 快 了 : 4 个 人 的 团 就 存在 6000 万 亿 种 可 能 :; 5 个 人 的 团 则 有 26 亿 亿 种 
可 能 ; 6 个 人 的 团 则 有 880 万 亿 亿 88 后 面 有 21 个 0) 种 可 能 。 很 快 ， 问 
题 的 规模 就 超出 了 机 器 的 处 理 能 


对 于 其 他 NP 完 全 问题 ， 搜 索 小 规模 的 解 可 能 会 简单 一 些 。 如 果 敌 友 国 
有 一 群 人 满足 如 下 条 件 : 即 对 任意 一 对 朋友 ， 都 至 少 有 一 个 人 在 这 和 群 人 
中 ， 那 么 这 样 一 群 人 被 称 为 一 个 舒适 组 (very cozy group ) 。 

















图 6-8 ”舒适 组 


在 这 个 好 友 关 系 图 中 ，Bob、Danielle、Frank 和 Harry 组 成 了 一 个 非常 舒 
适 的 组 ， 因 为 每 对 好 友 关 系 中 至 少 有 Bob、Danielle、EFrank 和 Harry 中 的 
hs 








图 6-9 包含 4 个 人 的 舒适 组 


在 这 个 好 友 关 系 图 中 ， 不 存在 3 个 人 的 舒适 组 。 例如， 如 果 我 们 把 
Alice、Charlie 和 Frank 这 3 个 人 看 做 舒适 组 ， 那 么 就 漏 反 了 Eve 和 
Danielle， 以 及 George 和 Harry 这 两 对 朋友 。 





图 6-10 包含 3 个 人 的 舒适 组 

舒适 组 问题 ， 即 人 们 熟知 的 “顶点 上 用 兰 问题 ”， 是 卡 普 原 来 列 出 的 NP 完 全 
问题 之 一 。 

我 们 来 看 图 中 的 Frank。 如 果 Frank 不 在 舒适 组 中 ， 那 么 George、Danielle 


和 Eve 必须 在 舒适 组 中 ， 因 为 他 们 都 和 Frank 是 朋友 关系 。 如 果 Frank 有 
100 个 朋友 ， 则 要 么 他 上 自己 在 舒适 组 中 ， 要 么 他 所 有 的 朋友 都 在 舒适 组 
中 。 





使 用 这 样 的 技巧 ， 计 算 机 科学 家 可 以 不 用 穷 举 就 能 找到 小 的 舒适 组 。 找 
到 5 个 人 的 舒适 组 只 需要 检查 大 概 100 000 种 可 能 。 找 10 个 人 的 组 则 需 检 
查 200 000 种 可 能 。30 个 人 的 组 则 是 601 000 种 所 有 这 些 用 你 的 笔记 
本 电脑 来 算 基本 上 有 瞬间 就 能 完成 。 搜 索 包 含 113 人 的 舒适 组 需要 检查 1 万 
亿 种 可 能 ， 其 计算 时 间 基 本 等 于 搜索 3 个 人 的 团 的 时 间 。 


等 一 下 ! 卡 普 不 是 证 明 找 到 最 小 的 舒适 组 也 是 NP 完全 问题 吗 ? 看 起 来 

寻找 舒适 组 并 不 怎么 困难 嘛 。 想 想 敌 友 国有 和 多少 对 好 友 关 系 。 这 么 多 的 
好 友 关 系 ， 舒 适 组 根本 不 可 能 只 用 区 区 113 人 就 保证 每 对 好 友 中 人 至少 有 

一 个 人 在 其 中 。 当 舒适 组 的 人 数 达 到 合理 的 规模 以 后 ， 相 应 的 必须 检验 
的 可 能 性 的 规模 会 变 得 非常 大 。 


如 果 你 寻找 的 是 150 人 的 组 ， 有 1500 万 亿 种 可 能 需要 搜索 ; 200 个 人 则 是 
10 万 亿 亿 种 〈1021) ; 而 500 人 ， 则 大 概 是 38 后 面 跟 51 个 0。 找 到 敌 友 国 
中 最 小 的 舒适 组 基本 上 是 不 可 能 完成 的 任务 。 但 如 果 我 们 只 是 在 100 个 
人 中 寻找 有 没有 舒适 组 ， 这 个 任务 还 是 可 以 在 合理 的 时 间 内 完成 的 。 






































6.4 近似 计算 方法 
也 许 我 们 没有 问题 的 最 佳 答案 ， 但 通常 一 个 不 坏 的 答案 就 足够 好 了 。 
比如 NP 完全 的 旅行 推销 员 问 题 ， 即 找到 访问 多 个 城市 的 最 短路 线 。 


如 果 我 想到 50 个 城市 旅行 ， 最 短 的 路 线 是 180 万 英里 ， 而 我 已 经 找到 了 
一 个 需要 181 万 英里 的 路 线 ， 通 第 大 可 不 必 为 多 走 的 1 万 类 里 劳 心 费 神 。 


换 一 个 角度 讲 ， 如 果 走 1 英里 要 花费 1 美元 ， 而 我 旅行 的 收入 是 180.5 万 
美元 ， 那 么 180 万 英里 和 181 万 英里 的 差别 ， 可 能 就 是 挣 5000 美 元 和 赔 
5000 美 元 的 差别 。 如 果 我 对 旅行 计划 作出 一 点 点 的 改进 ， 比 如 180.3 万 
英里 ， 那 我 就 可 以 扭亏 为 和合 了。 


里 然 地 图 上 的 旅行 推销 员 问 题 是 一 个 被 认为 难以 有 效 解决 的 NP 完全 问 
题 ， 但 是 我 们 可 以 找到 非常 接近 最 优 解 的 旅行 路 线 。 桑 吝 弗 ' 阿 多 拉 和 
弄 : 米 切 尔 给 出 了 一 个 算法 ， 原 理 是 先 将 地 图 切 分 为 许多 小 块 ， 然 后 在 
所 有 小 块 中 找到 小 段 的 最 佳 路 线 ， 最 后 通过 一 种 高 明 的 方式 将 这 些小 段 
的 路 线 连 接 起 来 。 


如 下 图 中 的 71 009 个 中 国 城市 。 








图 6-11 中 国 城市 


我 们 把 一 个 细密 的 网 格 套 在 地 图 上 ， 人 然后 在 每 个 小 格 中 求解 旅行 推销 员 
问题 。 如 宋 东 个 小 区 域 的 城市 太 多 ， 那 就 进一步 把 该 区 域 细 分 成 更 小 的 
网 格 。 


用 这 种 技术 ， 我 们 可 以 在 合理 的 时 间 内 ， 找 到 与 最 优 方案 只 差 百 分 之 几 
的 方案 。 





图 6-12 中国 城 市 的 网 格 


如 果 所 有 NP 问题 都 有 这 么 好 的 近似 计算 方法 ， 那 么 P/NP 问 题 儿 乎 就 不 
重要 了 。 人 然而 生活 没有 那么 轻松 。 比 如 团 问题 ， 即 找到 一 大 群 互 为 朋友 
的 人 。 目 前 还 不 存在 任何 通用 的 方法 可 以 估算 最 大 团 的 问题 。 政 友 国 可 
能 存在 2000 人 的 团 ， 但 在 合理 的 时 间 内 ， 我 们 连 15 人 的 团 都 找 不 到 。 


如 果 P=NP， 我 们 就 能 有 效 地 找到 全 局 最 大 团 。 这 被 证 明 是 能 稳定 地 找 
到 团 的 唯一 方式 ， 哪 怕 是 寻找 人 数 是 最 大 团 的 0.1% 的 团 ， 也 只 能 采取 这 
种 方式 。 发 现任 何 能 比 这 更 好 地 通过 估算 来 解决 团 问题 的 算法 ， 都 将 令 
P=NP， 即 有 效 地 解决 团 问题 本 身 。 


许多 NP 问题 既 不 像 团 问题 这 样 难以 估算 ， 文 不 像 地 图 上 的 旅行 推销 员 
问题 那样 容易 估算 。 让 我 们 回 过 头 再 来 看 看 舒适 组 问题 。 


像 这 样 一 个 小 规模 的 例子 ， 我 们 通过 穷 举 束 能 得 出 最 小 的 舒适 组 有 4 个 
人 ， 例 如 Frank、Danielle、Harry 和 Bob。 假 设 我 们 不 知道 这 一 点 ， 让 我 
来 描述 一 个 估算 最 小 舒适 组 的 简单 的 算法 。 














图 6-13 ”舒适 组 II 
首先 任 选 一 对 朋友 ， 比 如 Alice 和 Harry， 并 标记 他 们 。 





图 6-14 ”舒适 组 II，2 人 被 标记 
找到 另 一 对 没 被 标记 的 朋友 ， 然 后 也 标记 他 们 。 





图 6-15 ”舒适 组 II，4 人 被 标记 
重复 上 一 过 程 直到 找 不 到 未 被 标记 的 朋友 。 


图 6-16 ”舒适 组 I，6 人 被 标记 


最 后 ， 所 有 被 标记 的 人 组 成 的 将 是 一 个 舒适 组 。 


在 这 个 示例 中 ， 我 们 得 到 了 一 个 6 人 的 舒适 组 。 每 个 舒适 组 都 要 从 被 标 
记 的 3 组 好 友 中 每 组 至 少 选 一 个 人 ， 所 以 人 数 不 能 少 于 3 人 。 那 么 最 好 的 
舒适 组 的 人 数 应 该 在 3 到 6 之 间 。 


这 个 算法 适用 于 所 有 的 好 友 关 系 图 。 如 果 我 们 的 算法 找到 了 人 数 为 100 
的 舒适 组 〈 即 总 共 添 加 了 50 对 好 友 ) ， 那 么 我 们 知道 最 好 的 舒适 组 应 该 
在 50 到 100 人 之 间 。 


我 们 总 能 找到 一 个 舒适 组 ， 它 的 人 数 是 最 小 舒适 组 人 数 的 2 倍 。 我 们 能 
得 到 比 这 好 很 多 的 结果 吗 ? 也 许 不 能 。 


如 果 P=NP， 我 们 就 能 轻松 找 出 最 小 的 舒适 组 。 但 如 果 PzNP 呢 ?一 般 地 
讲 ， 不 可 能 找到 比 最 小 人 数 多 36% 或 更 小 的 舒适 组 。 任 何 能 找到 比 最 小 
人 数 多 36% 的 舒适 组 的 算法 ， 都 能 被 转化 为 一 个 可 解决 所 有 NP 问题 的 算 
法 。 这 个 转化 的 过 程 与 一 系列 在 1990 年 到 2005 年 之 间 证 明 的 艰深 结论 有 
Se 


上 面 介 绍 的 简单 算法 通过 逐个 添加 一 对 好 友 ， 能 找到 最 多 两 倍 于 最 小 人 
数 〈 也 就 是 比 最 小 人 数 多 100%) 的 舒适 组 。 如 果 PzNP， 那 么 我 们 能 
望 的 最 好 结果 就 是 找到 比 最 小 人 数 多 36% 的 舒适 组 。 我 们 有 可 能 找到 比 
最 小 人 数 多 50% 的 舒适 组 吗 ? 


为 解答 上 述 问 题 和 其 他 相关 问题 ， 计 算 机 科学 家 萨 布 哈 什 ' 霍 特 引 入 了 
一 种 他 称 为 独特 游戏 (uniqgue games) 的 问题 ， 该 问题 是 地 图 填 色 问题 
的 一 个 变种 ， 增 加 了 一 些 约束 相 邻 地 区 填 色 方式 的 规划。 独特 游戏 猜想 
是 说 独特 游戏 是 NP 完全 的 ， 人 们 至 今 无 法 判断 该 猪 想 是 否 为 真 !。 

1 关于 独特 游戏 和 独特 游戏 狂想， 参见 维基 百科 页 面 
http://en.wikipedia.org/wiki/Unique_games_conjecture。 一 一 译 者 注 

如 采 独 特 游戏 猜想 是 真 的 ， 我 们 甚至 可 以 进一步 约束 近似 计算 的 能 

霍 特 证 明 ， 如 果 该 猜想 为 真 ， 那 么 不 能 找到 比 最 小 人 数 的 2 倍 只 少 一 点 
的 舒适 组 。 如 果 该 猜想 为 真 ， 我 们 不 能 得 到 比 上 述 人 简单 算法 好 很 多 的 结 























6.5 解决 一 个 不 同 的 问题 


有 时 候 不 论 多 么 高 明 的 技巧 ， 都 对 茶 个 NP 问 题 无 能 为 力 。 那 么 ， 我 们 
可 以 试 着 解决 另 一 个 不 同 的 问题 。 


简 是 由 罗 奥 图 市 一 家 名 为 图 灵 之 家 〈Chez Turing) 的 餐馆 的 主 厨 ， 她 想 
研发 一 种 新 的 番茄 桨 来 搭配 她 的 名 沫 一 一 砂锅 意 面 。 图 灵 之 家 是 一 家 引 
领 风 潮 的 新 派 饭 店 ， 它 开创 了 计算 派 亲 系 。 简 不 直接 使 用 食物 做 试验 ， 
而 是 向 计算 机 输入 她 想 要 的 颜色 、 味 道 、 气 味 和 口感 ， 然 后 计算 机 就 会 
搜索 各 种 食材 的 组 合 ， 精 确 调配 出 所 需 的 口味 ， 这 样 研发 的 新 菜 不 仅 好 
lz， 并 且 降 低 了 制作 成 本 和 所 含 的 热量 。 这 一 次 ， 简 想 要 研发 一 种 深 红 
色 的 涂 ， 羡 辣 等 级 为 5， 口 感 类 似 燕麦 但 更 顺 滑 ， 能 轻 触 味蕾 5 和 11， 并 
能 对 砂锅 意 面 本 身 的 味道 产生 其 他 各 种 微妙 的 影响 ， 以 达到 完美 的 进食 
体验 。 


计算 机 没 能 找到 符合 她 所 有 要 求 的 食材 组 合 方式 。 于 是 简 打 电话 给 计算 
机 天 才 汤 姆 ， 他 答应 过 来 帮助 人 简 ， 顺 带 赚 取 一 顿 免费 大 餐 。 汤 姆 尝试 了 
他 知道 的 所 有 局 发 式 方法 ， 也 用 了 他 碍 到 的 几 种 新 方法 。 他 还 到 云端 ， 
租借 了 Amazon 机 器 上 的 计算 时 间 ， 试 图 用 真正 生猛 的 计算 能 力 来 攻破 
问题 。 而 那 也 没有 和 奏效。 他 接着 去 拜访 湾 区 的 所 有 朋友 ， 并 宣布 为 第 一 
个 找到 制作 次 料 方法 的 人 提供 一 个 令 人 垂 省 的 图 灵 之 家 的 预定 餐 位 。 一 
周 后 ， 所 有 人 都 表示 放弃 ， 因 为 这 个 问题 实在 太 难 解决 了 。 


汤姆 回去 告诉 简 这 个 坏 消息 。 这 是 他 第 一 次 没 能 找到 简 需 要 的 食材 和 制 
作 方 式 。 汤 姆 问 :“ 能 不 能 试 试用 其 他 方式 来 做 痊 料 ， 比 如 稍微 改变 一 
下 味道 ? ” 简 不 此 让 步 ， 认 为 资料 必须 要 具备 这 种 味道 和 口感 ， 否 则 会 
破坏 砂锅 意 面 在 口中 的 感觉 。 汤 姆 又 问 :“ 那 砂锅 意 面 本 喘 昵 ? ” 


既然 为 这 种 特定 的 砂锅 意 面 找到 合适 的 普 汗 是 一 个 很 难 的 计算 问题 ， 简 
和 汤姆 转 而 搜索 新 的 能 够 完美 韶 合 的 砂锅 意 面 和 桨 闭 。 这 个 任务 稍微 容 
易 计 算 一 些 ， 计 算 机 在 数 小 时 内 就 输出 了 一 份 食物 配方 。 通 过 改变 要 解 
决 的 问题 ， 图 元 之 家 又 有 了 一 道 新 的 招牌 菜 。 


在 忆 一 种 情境 中 ， 改 变 要 解决 的 问题 则 令 计 算 机 安全 专家 们 头痛 不 已 ， 
他 们 开发 出 的 最 新 加 蜜 技术 能 让 交易 变 得 更 加 安全 ， 前 提 是 坏 香 只 用 专 




















家 们 预想 到 的 方法 来 破译 密码 。 但 是 坏 皇 们 往往 不 按 套路 出 牌 ， 却 偶尔 
能 乍 打 正 厦 。 


智能 卡 表 面 上 和 信用 卡 一 样 ， 但 里 面 内 其 了 一 个 小 小 的 处 理 堪 ， 存 储 着 
一 个 密 钥 。 智 能 卡 可 以 用 来 识别 有 身份， 也 能 存 少量 的 钱 ， 这 样 你 在 商店 
购物 或 者 泊 车 咪 表 处 交 费 时 ， 就 不 用 和 集约 化 的 计算 机 进行 连接 和 通信 
0 0 
青 出 密 钥 。 


假如 托 蕊 斯 在 酒店 工作 ， 趁 安妮 去 游泳 的 时 候 拿 了 她 的 智能 卡 。 托 马 斯 
有 一 个 特殊 的 读 卡 器 ， 用 它 能 试 着 给 智能 卡 发 送 一 些 数据 ， 然 后 看 看 返 
回 了 些 什 么 数据 。 如 果 P=NP， 那 么 狠 贼 能 根据 这 些 输入 /输出 行为 找到 
密 钥 。 而 我 们 更 有 可 能 生活 在 PzZNP 的 世界 里 ， 找 到 密 钥 是 很 困难 的 。 
智能 卡 数据 交换 协议 是 经 过 精心 设计 的 ， 本 革 所 到 的 下 力 搜索 或 启发 式 
算法 等 技术 对 于 找到 密 钥 都 收效 甚 微 。 如 末 找 不 到 密 钥 ， 托 号 斯 通常 只 
能 把 卡 还 给 安妮 ， 或 者 当 安 妮 发 现 卡片 丢失 ， 直 接 给 银行 打 电 话 注 销 这 
张 卡 。 


而 托马斯 不 是 一 般 的 号 份 历 贼 。 他 能 以 设计 者 意 想 不 到 的 方式 来 “使 
用 ”智能 卡 。 他 把 卡 扔 到 微波 炉 里 加 热 几 秒 。 你 可 别 在 家 答 试 这 个 ， 微 
波 炉 的 能 量 会 让 智能 卡 或 任何 其 他 电子 设备 接近 报废 。 即 使 是 很 短 时 间 
的 微波 加 热处理 ， 也 可 能 导致 某 些 电路 的 短路 ， 即 使 不 是 永久 性 地 损伤 
智能 卡 ， 也 会 让 它 的 输入 /输出 行为 变 得 无 法 预料 。 


无 法 预料 的 行为 正 是 托马斯 想 要 的 。 如 果 智 能 卡 正常 工作 ， 他 也 许 不 知 
道 如 何 找到 密 钥 。 而 一 个 略微 受 损 的 智能 卡 虽 然 仍 可 以 对 输入 的 数据 做 
出 啊 应 ， 但 是 输入 /输出 的 行为 也 和 原来 不 一 样 了 。 


新 的 输入 /输出 行为 仍 与 密 钥 有 关 ， 但 是 原来 那 种 令 密 钥 难 以 被 找到 的 
设计 失效 了 。 这 时 如 果 托 马 斯 再 使 用 局 发 式 或 蛮 力 搜索 等 方法 来 寻找 密 
钥 ， 就 有 可 能 奏效 。 


一 旦 托马斯 找到 密 钥 ， 他 就 能 用 它 制 作 两 个 和 安妮 原先 正常 的 卡片 一 模 
一 样 的 智能 卡 。 托 马 斯 把 其 中 之 一 还 给 安妮 ， 另 一 个 留 给 目 己 。 托 马 斯 
如 果 足 够 小 心 的 话 ， 束 可 以 从 安妮 的 账户 偷 钱 ， 而 安妮 和 银行 可 能 要 等 
儿 周 或 几 个 月 后 才 会 发 现 问 题 。 




















托马斯 找到 密 钥 的 方式 是 ， 把 一 个 被 故意 设计 成 难以 解决 的 NP 问 题 转 
变 为 一 个 完全 没 极 设计 过 的 问题 。 新 一 代 的 智能 卡 已 经 拥有 了 对 抗 微波 
攻击 的 机 制 。 但 我 们 绝 不 能 低估 那些 一 心 想 找到 秘密 信息 的 家 伙 们 的 想 
象 力 。 


6.6 ”接受 现实 


有 时 候 一 个 问题 天 生 排 斥 任何 可 能 解决 它 的 方法 ， 对 此 你 能 做 的 只 有 放 
弃 ， 然 后 去 干 点 别 的 。 


理 查 德 偶然 发 现 了 一 种 超级 药物 的 化 学 式 ， 这 种 药 能 让 他 主宰 世界 ， 或 
者 至 少 是 主宰 大 辛辛那提 区 。 他 制定 了 一 个 向 米 勒 市 水 处 理 厂 投放 药物 
的 计划 ， 喝 了 水 的 居民 将 失去 警惕 ， 变 得 非常 容易 被 操控 。 到 那 时 ， 理 
查 德 就 能 “挺身 而 出 ”， 接 管 他们 的 社会 。 


只 要 收集 到 足够 多 的 合适 的 化 学 品 ， 理 查 德 就 能 实现 他 的 梦想 。 不 笠 的 
是 ， 以 前 发 生 的 茶 次 事件 导致 政府 茶 止 了 供应 丙 直 接 癌 任何 个 人 出 售 这 
些 化 学 品 。 于 是 理 碍 德 开 始 分 析 如 何 分 解 各 种 日 用 品 ， 然 后 从 原料 中 制 
备 这 些 化 学 品 。 理 得 德 往 笔记 本 电脑 里 输入 了 各 种 参数 : 购买 日 用 品 的 
成 本 ， 从 大 壮 闻 那 提 区 的 20 个 沃尔玛 和 14 个 Targets 超 市 能 够 安全 购买 而 
不 引起 怀疑 的 每 种 日 用 品 的 数量 ， 运 输 和 仓储 的 成 本 《他 需要 好 几 个 仓 
库 来 放 买 来 的 东西 ) 。 有 好 多 种 日 用 品 的 组 合 可 供 选择 。 他 把 这 些 参数 
输入 电脑 ， 但 是 需要 检查 的 可 能 性 数量 太 多 了 ， 计 算 机 无 法 找到 符合 他 
的 时 间 和 资金 限制 的 方案 。 他 打 心 眼 里 觉得 一 定 存在 满足 所 有 条 件 的 方 
和 案 ， 但 不 管 他 怎么 等 试 ， 用 尽 了 所 有 他 从 网 上 能 找到 的 局 发 式 方法 和 舍 
计算 法 ， 就 是 找 不 到 这 样 一 个 能 趴 齐 所 需 化 学 品 的 方案 。 最 终 理 碍 德 放 
弃 了 ， 回 到 他 在 本 地 牙膏 三 的 保安 岗位 上 。 


束 这 样 ，NP 问 题 的 复杂 性 拯救 了 辛辛那提 。 























6.7 总 结 

通常 ， 只 一 种 技术 不 足以 处 理 人 们 面临 的 困难 的 NP 问题 。 我 们 经 常 需 
要 尝试 本 章 提 到 的 几 种 技术 。 如 果 无 法 解决 需要 解决 的 问题 ， 那 么 可 以 
尝试 解决 一 个 不 同 的 问题 。 如 果 新 的 问题 仍然 是 NP 完全 问题 ， 屠 我们 
还 可 以 用 某 些 启发 式 方法 来 对 它 发 起 进攻 。 启 发 式 方法 很 少 能 完全 地 解 
决 问题 ， 但 是 它们 可 以 给 出 足够 好 的 近似 解决 方案 。 


如 末 P=NP， 所 有 这 些 问 题 都 将 烟消云散 ， 我 们 将 用 一 个 简单 的 算法 做 
很 多 不 简单 的 事情 。 但 即使 事实 如 我 们 料想 的 那样 〈 即 PNP) ， 我 们 
还 是 几乎 总 能 收获 点 什么 。 可 能 过 程 中 需要 付出 更 多 的 努力 ， 可 能 最 终 
解决 的 问题 和 最 想 解 决 的 问题 不 太一 样 ， 可 能 根本 无 法 得 到 最 好 的 解决 
方案 。 但 是 ， 如 果 我 们 仍然 能 把 事情 做 完 ， 那 就 足够 好 了 。 











第 7 章 ”证 明 PzNP 


尤 里 斯 - 哈 特 马 尼 斯 是 计算 复杂 度 理论 的 葛 基 人 之 一 ， 他 曾 说 : “我们 者 
知道 P 和 NP 不 一 样 ， 但 就 是 不 知道 如 何 证 明 这 一 点 。” 


我 们 在 前 面 几 章 中 从 多 方面 探讨 了 P/NP 问 题 ， 包 括 它 是 什么 ， 它 的 研究 
意义 ，P=NP 的 虚幻 美妙 世界 ， 以 及 如 何 处 理由 PzNP 带 来 的 困难 问题 。 


P/NP 问 题 也 是 一 个 迷人 而 富有 挑战 性 的 数学 问题 。 从 库 克 、 卡 普 和 莱 文 
将 这 个 问题 及 其 重要 意义 呈现 给 世界 的 那 一 刻 起 ， 计 算 机 科学 家 和 数学 
家 就 一 直 努 力 形式 化 地 证 明 P=NP 或 PzNP。 但 所 有 常规 的 手段 都 失效 
了 。 到 20 志 纪 70 年 代 末 ， 大 家 达成 的 共识 是 “P/NP 问 题 的 解决 可 能 有 赖 
于 大 幅度 创新 的 证 明 技 术 ”。 














我 这 么 说 也 许 有 点 冒 |[ 对 于 大 多 数 人 来 说 讲 不 
类， 但 是 训 明 不 可 能 ||| 通 ， 但 我 可 是 受过 专业 
做 到 森 件 事 ， 这 在 逻 | 内 训练 的 科学家 。 

辑 上 说 得 通 吗 ? 


你 好 ， 我 是 一 名 反 逻 辑 |# 
学 的 科学 家 。 我 能 证 明 | 
你 正在 写 的 那个 软件 不 |3 
可 能 正常 工作 





图 7-1 DILBERT © 1997 Scott Adams。 使 用 需 得 到 
UNIVERSALUCLICK 的 许可 ， 版 权 所 有 ， 侵 权 必 究 


接 下 来 的 几 十 年 中 ， 计 算 机 科学 和 数学 都 取得 了 不 可 思议 的 进步 ， 包 括 
解决 了 所 有 未 解决 数学 问题 中 最 著名 的 一 个 一 费 马 大 定理 。1637 年 左 
右 ， 法 国 律师 兼 数学 爱好 者 皮 埃 尔 . 德 . 费 马 在 他 的 《算术 》 (一 本 十 希 
腊 教 科 书 ) 的 书页 边缘 上 写 下 如 下 这 样 一 段 文字 : 

将 一 个 立方 数 分 成 两 个 立方 数 之 和 ， 或 一 个 四 次 宕 分 成 两 个 四 次 宕 之 
和 ， 或 更 一 般 地 ， 将 一 个 高 于 二 次 的 昭 分 成 两 个 同 次 窜 之 和 ， 都 是 不 
可 能 的 。 对 此 我 确信 已 发 现 了 一 种 美妙 的 证 明 方法 ， 可 惜 这 里 空白 的 
地 方太 小 ， 写 不 下 。 


也 就 是 将， 不 存在 大 于 0 的 三 个 目 然 数 o、b 和 c， 以 及 大 于 2 的 目 然 数 m， 














能 令 q"+b"=c?。 费 瑟 再 也 没有 提 到 这 个 定理 的 证 明 方法 ， 也 有 可 能 他 压 
根 就 没 想 出 正确 的 证 法 。 后 来 这 个 问题 闻名 于 世 ， 成 为 一 个 经 典 的 数学 
未 解 之 恋 。 我 小 时 候 也 梦想 成 为 第 一 个 解决 这 个 着 名 问题 的 人 。 为 外 一 
个 和 我 有 着 共同 梦想 的 小 孩 长 大 后 实现 了 他 的 梦想 。1994 年 ， 普 林 斯 顿 
大 学 的 数学 家 安德鲁 : 怀 尔 斯 在 前 人 发 表 的 一 系列 有 关 数 论 的 论文 基础 
上 ， 构 造 出 了 费 马 定理 的 证 明 。 他 立刻 成 了 名 人 ， 至 少 拥 有 了 作为 一 个 
数学 家 所 能 够 译 有 的 无 上 末次。 


这 一 草 不 会 告诉 你 如 何 解 决 NP 问 题 ， 人 否则 这 将 是 一 本 非常 不 同 的 书 。 
我 们 只 会 介绍 一 些 人 们 在 尝试 解决 P/NP 问 题 时 曾经 产生 过 的 想法 。 可 
惜 ， 这 些 想 法 没 能 让 我 们 距离 解决 该 问题 更 近 一 点 。 要 证 明 PzxNP， 惑 
要 证 明 不 存在 能 解决 菜 些 NP 问题 的 算法 (甚至 包括 那些 未 被 及 现 的 算 
法 ) 。 很 难 去 证 明 不 可 能 做 成 条 件 事 ， 尺 管 这 在 逻辑 上 并 非 不 可 能 。 所 
以 ， 对 于 这 个 也 许 是 所 有 数学 问题 中 最 为 重要 同时 最 上 其 挑战 性 的 问题 ， 
我 们 还 是 希望 看 到 它 被 解决 的 那 一 天 。 











7.1 ”骗子 那 论 
请 考虑 如 下 这 个 令 人 困惑 


(ey 
到 
全 
涪 


This sentence is Not true, 


图 7-2 方 框 中 的 命题 ， 这 个 命题 不 是 真 的 


这 个 命题 是 真是 假 ? 如 果 它 是 假 的 ， 那 么 它 不 能 不 是 真 的 ， 双 重 否 定 意 
味 着 它 是 真 的 。 如 果 这 个 命题 是 真 的 ， 那 么 如 其 所 说 ， 它 不 古 真 的 而 是 
假 的 。 两 种 假设 ， 都 会 寻 致 矛盾 。 这 个 悖 论 经 常 被 称 为 骗子 悖 论 。 我 现 
在 正在 撒谎 。 你 觉得 呢 ? 


展 好 的 数学 系统 中 是 不 允许 出 现 正 确 的 悖 论 的 ， 悖 论 的 存在 说 明 数 学 系 
统 不 够 好 。“ 这 个 命题 不 是 真 的 ”是 不 可 被 数学 规范 化 的 ， 因 为 一 个 命题 
不 能 讨论 它 本 刁 的 真 伪 。 

20 世 纪 30 年 代 ， 库 尔 特 : 哥 德尔 及 现 了 数学 可 以 讨论 证 明 的 真 伪 ， 他 可 
以 构造 一 些 数学 命题 ， 来 表明 其 他 的 命题 是 否 存 在 能 证 明 其 正确 性 的 证 
据 。 哥 德尔 太 现 了 如 何 让 一 个 命题 讨论 它 本 里 正确 性 的 证 明 是 否 存在 的 
方法 ， 并 建 并 了 一 个 与 上 面 类 似 的 数学 公式 : 


| There is no proof that this sentence is true, ] 


图 7-3 方 框 中 的 证 据 : 没有 证 据 表 明 这 个 命题 是 真 的 


假设 这 个 命题 为 假 ， 那 么 有 证 据 表 明 这 个 命题 是 真 的 ， 这 和 它 为 假 的 假 
设 了 矛盾 ， 所 以 这 个 命题 必须 是 真 的 。 
我 们 又 过 到 悖 论 了 吗 ? 不 完全 是 。 这 个 命题 是 真 的 ， 然 而 没有 证 据 表 明 
它 征 真 的 。 哥 德尔 看 似 轻描淡写 的 一 击 ， 却 手动 了 数学 大 厦 的 基础 : 存 
在 人 们 不 能 证 明 其 为 真 的 真 命题 。- 


1 我 们 刚才 没有 证 明 那 个 命题 是 真 的 吗 ? 不 完全 如 此 ， 因 为 不 得 不 首先 假设 所 有 能 被 证 明 为 真 
的 命题 都 确实 是 真 的 。 于 是 哥 德 尔 同时 也 表明 了 ， 我 们 不 能 证 明 “ 所 有 能 被 证 明 为 真 的 命题 都 确 



























































实 是 真 的 ”， 除 非 我 们 能 证 明 假 的 命题 。 这 就 是 你 读 脚注 的 好 处 。 


如 果 有 人 告诉 你 他 有 一 个 能 预测 未 来 的 魔 盒 。 你 就 问 他 你 会 用 右手 打 他 
还 是 用 左手 。 如 果 盒 子 说 左手 ， 你 束 用 右手 打 那 个 人 。 如 果 盒 子 说 石 
手 ， 你 就 用 左手 。 不 管 怎样 金子 都 是 错 的 。 


计算 也 同样 可 以 这 样 。 我 们 都 见 过 计算 机 屏幕 上 出 现 一 个 代表 忙碌 的 小 
沙漏 ， 不 知道 这 是 代表 计算 机 死机 了 ， 还 是 在 进行 长 时 间 的 计算 。 用 户 
该 马上 重启 机 器 呢 ， 还 是 再 等 一 会 儿 ? 如 果 能 有 一 个 算法 ， 告 诉 我 们 计 
算 机 是 不 是 陷 进 了 茶 种 无 穷 循环 该 多 好 ! 那 是 很 好 ， 但 那 也 是 不 可 能 
的 。 


为 理解 其 中 的 道理 ， 我 们 先 来 看 一 下 1936 年 阿兰 :图 灵 在 开创 计算 机 科 
学 的 论文 中 给 出 的 一 个 例子 。 计 算 机 程序 也 是 数据 ， 就 像 文档 和 报表 一 
样 。 程 序 可 以 分 析 程 序 的 代码 。 


一 个 计算 机 程序 要 么 最 终结 束 计算 并 输出 结果 ， 要 么 永远 算 下 去 。 假 设 
我 们 有 一 个 算法 ， 它 能 告诉 我 们 某 个 程序 是 否 会 最 终结 束 。 我 们 把 这 个 
程序 对 它 本 里 运行 一 下 。 


Sn 























lf the program inside this box finishes then run forever. 








这 个 方 框 中 的 程序 要 么 会 结束 ， 要 么 不 会 结束 。 不 管 怎样 ， 我 们 都 遇 到 
了 艺 盾 。 所 以 我 们 的 假设 是 错误 的 ， 即 不 存在 一 个 程序 ， 能 告诉 我 们 茶 
个 程序 能 人 否 最 终结 束 。PC 上 没有 ，Mac 上 也 没有 。 现 在 没有 ，100 年 后 
也 不 会 有 。 不 存在 一 个 程序 能 告诉 我 们 茶 个 程序 能 人 否 最 终结 束 ， 就 这 么 
简单 。 

我 们 能 用 类 似 的 思路 来 证 明 人 们 无 法 高 效 地 解决 未 些 问 题 ， 也 就 是 证 明 
A 
和。 


我 们 先 构 造 一 个 算法 Q， 将 一 段 程序 R 的 代码 作为 其 输入 数据 ， 它 的 工 
作 原 理 如 下 : 


。 如 果 程 序 R 在 使 用 R 的 代码 作为 数据 时 能 很 快 输出 “Yes”"， 那 么 Q 输 
出 “No”; 
。 否则 Q 输 出 “Yes”。 





假设 算法 S 是 一 个 高 效 的 算法 。 那 么 ，Q(S) 当 且 仅 当 S(S) 输 出 “No” 的 时 
候 和 输出 “Yes”。 所 以 不 存在 行为 与 Q 完 全 相同 的 高 效 算 法 。 


Q 仍 然 是 一 个 符合 规范 的 算法 。 所 以 Q 所 解决 的 这 个 问题 是 可 被 计算 
的 ， 但 不 能 们 高 效 地 计算 。 


如 果 我 们 能 证 明 Q 在 NP 中 ， 也 就 是 说 ， 可 以 高 效 地 验证 其 解 的 有 效 性 ， 
那么 Q 在 NP 中 ， 而 不 在 P 中 。 这 意味 看 PzNP， 从 而 解决 了 那个 伟大 的 问 


匮 。 


但 是 我 们 不 知道 ， 而 且 通 常 不 认为 ， 存 在 一 个 关于 Q 的 NP 算法 。 由 于 这 
个 原因 以 及 其 他 的 某 些 原 因 ， 这 条 试图 以 悖 论 来 解决 P/NP 问 题 的 道路 注 
定 会 通 向 失败 ， 至 少 它 不 能 直接 用 来 证 明 PzNP。 


7.2 电路 
现代 计算 设备 的 核心 都 有 一 块 集成 电路 板 。 
集成 电路 由 上 百 万 或 上 百 亿 个 微小 的 晶体 管 组 成 。 唱 体 管 是 一 种 能 放大 


并 控制 电子 脉冲 的 元 件 ， 它 们 实现 了 逻辑 门 〈gate) ， 即 一 些 构建 在 带 
有 电荷 的 导线 上 的 简单 逻辑 操作 。 
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图 7-5 电路， 图 片 由 宾夕法尼亚 大 学 电子 和 系统 工程 系 提 供 


我 们 首先 来 看 简单 的 导线 。 每 根 线 要 么 带 有 高 电压 ， 要 么 带 低 电压 ， 只 
能 取 两 个 值 中 的 一 个 ， 这 经 常 被 表示 为 开 和 关 、1 和 0， 或 是 真 和 假 。 我 
们 将 这 些 二 元 系统 称 之 为 比特 (bit) ， 即 “二 元 数字 ”(binary digit) 的 
简称 。 


一 根 导线 做 不 了 什么 ， 几 根 在 一 起 也 能 力 有 限 。 为 了 构成 计算 能 力 ， 我 
们 要 对 导线 上 的 信息 进行 一 些 逻 辑 操 作 。 其 中 最 简单 的 就 是 翻转 导线 的 
值 ， 这 叫做 非 门 (NOT gate) 。 





真 假 假 真 


图 7-6” 非 门 
如 果 非 门 的 左边 有 电压 ， 那 么 右边 就 没有 ， 反 之 亦 然 。 


计算 的 真正 力量 并 不 是 对 单个 导线 的 操作 ， 而 来 自 于 将 多 条 导线 的 值 以 
某 种 机 制 合 并 。 与 门 AND gate) 将 2 条 或 更 多 条 导线 的 值 合并 为 一 个 
值 ， 该 值 仅 在 所 有 导线 的 值 都 为 真 时 为 真 。 或 门 〈OR gate) 将 2 条 或 更 
多 条 导线 的 值 合 并 为 一 个 值 ， 该 值 在 至 少 有 一 条 导线 的 值 为 真 时 为 真 。 
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图 7-7 与 门 和 或 门 


我 们 能 用 这 些 人 简单 模块 构建 更 复杂 的 人 逻辑 操作 。 比 如 ， 两 条 导线 做 寞 或 
操作 (Exclusive-OR) 的 值 只 在 仅 有 一 条 导线 的 值 为 真 时 为 真 。 





图 7-8” 异 或 门 


每 一 个 函数 ， 无 论 它 多 复杂 ， 都 能 用 与 、 或 、 非 三 种 门 组 成 的 电路 来 计 
算 。 让 我 们 回顾 一 下 敌 友 国 的 团 问题 ， 即 我 们 想 找 到 一 群 彼 此 互 为 好 友 
的 人 。 我 们 可 以 用 一 个 与 门 来 表示 Alice、Bob 和 Carol 是 否 互 为 朋友 。 








Alice 和 Bob 是 好 友 关 系 吗 ? 
Bob 和 Carol 是 好 友 半 系 吗 ? 


Alicec 和 Carol 是 好 友 关 系 吗 ? 


Alice 、Bob 和 Carol 可 以 组 成 一 个 团 吗 ? 





图 7-9 与 门 


假设 我 们 想 知 道 在 Alice、Bob、Carol、David 和 Eli 中 是 否 存在 3 个 人 的 
团 。 我 们 用 图 7-10 中 的 电路 来 计算 这 个 问题 。 


这 个 电路 有 10 个 与 门 ， 表 示 的 是 从 5 人 里 面 找 出 可 能 成 团 的 3 个 人 ， 共 有 
10 种 可 能 。 假 设 我 们 现在 要 从 收 友 国 的 2 万 人 中 找 出 50 人 的 团 。 直接 转 
换 的 电路 将 有 


3 481 788 616 673 927 174 126 704 329 430 033 822 428 741 136 969 800 
292 509 234 146 086 195 855 824 730 457 281 170 250 134 309 383 506 
694 008 809 661 825 431 661 561 845 957 650 386 210 936 569 600 


个 与 门 ， 规 模 大 到 无 法 实现 。 





与 ABC 


3 人 团 ? 





图 7-10” 团 问题 的 电路 


这 和 P/NP 问 题 有 什么 关系 呢 ? 每 一 个 P 中 的 问题 〈 即 每 一 个 能 被 高 效 地 
求解 的 问题 )》， 都 对 应 一 个 规模 相对 较 小 的 由 与 、 或 、 非 门 构成 的 电 
路 ， 并 且 该 电路 能 够 求解 该 问题 。 如 果 我 们 能 证 明 某 些 NP 中 的 问题 

(例如 团 问 题 》， 不 能 对 应 一 个 小 规模 的 电路 ， 那 么 就 证 明 了 NPzP。 


那 是 否 能 证 明 团 问题 不 能 对 应 小 规模 的 电路 ? 这 个 问题 和 P/NP 问 题 密切 
相关 ， 同 样 也 是 未 知 的 ， 尽 管 大 部 分 计算 机 科学 家 都 相信 团 问 题 不 对 应 
小 规模 的 电路 ， 正 如 他 们 相信 PzNP 一 样 。 








看 看 我 们 上 面 为 团 问题 构造 的 电路 。 注 意 其 中 没有 非 门 。 不 是 所 有 的 问 
题 都 能 对 应 不 含 非 门 的 电路 ， 比 如 简单 的 异 或 操作 的 电路 就 必须 包含 非 
门 。 然 而 ， 团 问题 融 可 以 用 只 有 与 门 和 或 门 的 电路 来 计算 ， 尽 管 这 些 电 
路 的 规模 极为 庞大 。 


1985 年 ， 砚 斯 科斯 捷克 洛 夫 数学 研究 所 的 一 名 学 生 亚 历 山 大 : 拉 效 波 洛 
夫 证 明 ， 如 果 电 路 只 包含 与 门 和 或 门 〈 疫 有 非 门 )》 ， 那 么 任何 能 求解 团 
问题 的 电路 必须 使 用 数量 极 多 的 逻辑 门 。 这 并 没有 解决 P/NP 问 题 。 因 为 
里 然 可 以 在 求解 团 问题 的 电路 中 不 使 用 非 门 ， 但 说 不 定 使 用 非 门将 显著 
降低 电路 所 需 的 逻辑 门 的 数量 。 


尽管 如 此 ， 拉 兹 波 洛 夫 的 工作 曾 被 看 成 是 有 望 解决 RNP 问 题 的 突破 性 进 
展 。 我 的 博士 生 导 师 迈 元 尔 : 窄 普 斯 当年 认为 P/NP 问 题 的 解决 指 日 可 
竺 。 需 要 做 的 只 是 对 拉 效 波 洛 夫 的 方法 稍 加 改进 ， 让 它 也 适用 于 非 门 。 
如 果 成 功 ， 那 么 作为 NP 问题 之 一 的 团 问 题 ， 其 求解 电路 必须 要 使 用 数 
量 极 大 的 与 、 或 、 非 三 种 逻辑 门 。 所 以 团 问题 没有 高 效能 的 算法 ， 因 为 
所 有 高 效能 的 算法 都 可 转化 为 小 规模 的 电路 。 这 样 一 来 ， 团 问题 属于 
NP 但 不 属于 P， 从 而 证 明 PzNP。 不 幸 的 是 ， 生 活 并 没 那么 简单 。 


拉 效 波 洛 夫 发 表 的 那些 论文 是 用 俄 文 写 的 。 在 论文 到 达 美 国 后 ， 竖 普 期 
名 集 了 几 个 苏联 学 生 ， 大 家 仔细 地 进行 翻译 ， 并 且 盼 望 着 拉 效 波 洛 夫 的 
下 一 篇 论文 能 给 PINP 问 题 夯 上 一 个 圆满 的 句号 。 拉 效 波 洛 夫 后 来 发 表 了 
更 多 优秀 的 论文 ， 但 其 中 没有 一 篇 是 给 出 PzNP 的 证 明 的 。 


在 第 3 章 我 们 介绍 过 政 友 国 的 配对 间 题 ， 即 按 好 友 关 系 为 政 友 国 的 一 些 
居民 牵线 搭桥。 配对 问题 和 团 问 题 一 样 ， 也 对 应 只 使 用 与 门 和 或 门 的 电 
路 。 证 明 团 问题 对 应 需要 大 量 与 门 和 或 门 的 电路 所 用 的 方法 ， 同 样 也 适 
用 于 配对 问题 。 任 何 只 用 与 门 和 或 门 解 决 配对 问题 的 电路 ， 都 需要 极 大 
数量 的 馆 辑 门 。 


和 团 问 题 不 同 ， 我 们 有 解决 配对 问题 的 高 效 算法 。 所 以 ， 配 对 问题 存在 
使 用 与 、 或 、 非 三 种 逻辑 门 的 小 规模 电路 。 非 门 对 于 求解 配对 问题 不 是 
必要 的 ， 但 是 使 用 非 门 会 显著 降低 电路 所 使 用 的 迎 辑 门 的 数量 。 看 上 去 
十 分 低级 和 简单 的 非 门 ， 况 然 缠 含 着 巨大 的 力量 。 


这 个 事实 让 那些 企图 利用 拉 效 波 洛 夫 求解 团 问 题 的 方法 来 解决 PNP 问 题 
的 答 试 遭受 了 极 大 的 挫折 。 即 使 证 明了 某 个 问题 在 只 使 用 与 门 和 或 门 时 





























电路 规模 很 大 ， 也 并 不 能 保证 在 引入 非 门 后 电路 的 规模 仍然 会 很 大 。 后 
来 拉 效 波 洛 夫 的 工作 澄清 了 这 方面 的 问题 。 他 明确 地 指出 了 他 的 证 明 在 
考虑 到 非 门 时 变 得 分 月 离 析 ， 并 且 无 法 修补 。 

后 来 ， 拉 效 波 洛 夫 和 卡 内 基 梅 隆 大 学 的 史 带 文 : 鲁 迪 赫 引 入 了 “自然 证 
明 ”(natural proof〉 的 概念 。 目 然 证 明 涵 盖 了 电路 的 各 种 证 明 方 法 中 的 
很 大 一 部 分 ， 并 给 出 了 很 强 的 证 据 表 明 不 可 能 用 这 些 方法 解决 P/NP 问 


匮 。 


同时 ， 使 用 非 “ 自 然 * 的 、 基 于 本 章 前 面 提 到 的 悖 论 思 想 的 方法 来 构造 电 
路 的 尝试 ， 也 取得 了 一 些小 小 的 进展 。 然 而 试图 通过 “证 明 某 个 NP 问题 
再 要 大 规模 的 求解 电路 ”的 方法 来 找到 P/NP 问 题 的 答案 ， 可 能 性 已 经 变 
得 微乎其微 。 











7.3 ”证明 PxNP 时 常 犯 的 错误 


2010 年 8 月 6 日 ， 惠 普 实 验 室 的 科学 家 维 纳 里 . 德 奥 拉 利 卡 向 22 位 顶尖 的 
理论 计算 机 科学 家 发 送 了 他 写 的 论文 ,题目 简洁 有 力 :“PzNP”。 曾 经 
有 许多 追逐 名 利 〔 克 雷 数 学 研究 所 提供 的 百 万 奖金 ) 的 人 给 出 了 P/NP 问 
题 的 各 种 “证 明 ”， 他 们 认为 PzNP 或 P=NP， 或 者 不 可 能 判定 P 是 否 等 于 
NP， 或 者 声称 PINP 问 题 根本 惑 坚 无 让 理 。 每 年 都 会 涌现 很 多 这 类 证 明 
的 手稿 ， 有 的 被 发 送 到 计算 机 科学 家 的 电子 邮箱 里 ， 有 的 被 提交 到 学 术 
期 刊 ， 还 有 的 直接 公布 在 互联 网 上 。 最 著名 的 计算 机 科学 期 刊 持续 地 收 
到 声称 解决 了 P/NP 问 题 的 来 稿 ， 后 来 ， 该 期 刊 宣布 了 一 条 对 这 些 文章 的 
特殊 规定 。 


The Journal of the ACM (JACM) 经 营 收 到 来 稿 ， 声 称 解决 了 复杂 度 
理论 领域 一 个 长 期 悬而未决 的 问题 ， 即 PINP 问 题 。 这 些 来 稿 严重 占用 
了 JACM 上 自愿 提供 的 编辑 和 审查 资源 ， 因 为 需要 一 定 的 时 间 才 能 辨识 
其 中 的 错误 。JACM 仍 然 对 P/NP 及 相关 问题 的 解决 保持 开放 的 心态 ， 
并 将 继续 欢迎 针对 这 个 主题 的 投稿 。 然 而 ， 为 了 减轻 由 屡次 重复 提交 
并 逐一 订正 错误 而 带 来 的 负担 ， 本 刊 决定 采取 如 下 规定 : 对 于 P/NP 这 
个 复杂 度 理论 领域 长 期 未 解决 的 问题 或 与 之 相关 的 主题 ， 任 何 作者 在 
24 个 月 的 周期 内 只 能 提交 一 入 文章， 除非 受到 主编 的 约 稿 。 此 规定 也 
适用 于 之 前 被 拒 稿件 的 再 次 提交 。 


在 这 些 对 解决 P/NP 问 题 的 尝试 中 ， 大 部 分 要 么 不 知 所 云 ， 要 么 明显 是 错 
误 的 ， 学 术 界 对 此 基本 上 视而不见 。 而 德 奥 拉 利 卡 的 文章 则 受到 了 特殊 
的 待遇 。 他 本 人 在 过 去 曾 发 表 过 研究 论文 ， 并 且 这 篇 论文 的 写作 水 平 超 
出 了 大 部 分 的 P/NP 投 稿 。 于 是 有 的 理论 学 家 感到 有 必要 仔细 研读 一 下 这 
篇 论文 。 这 在 互联 网 上 引起 了 轩然大波 ， 一 些微 博 和 博客 甚至 急 不 可 耐 
地 提前 宣布 P/NP 问 题 得 到 了 解决 。 几 个 著名 的 计算 机 科学 家 和 数学 家 在 
仔细 研读 了 德 奥 拉 利 卡 的 论文 后 ， 发 现 了 其 中 的 几 处 缺陷 ， 有 一 些 是 小 
下 漏 ， 另 一 些 则 是 大 错 特 错 。8 月 16 日 ， 也 就 是 论文 公布 后 的 第 10 天 ， 
纽约 时 报 发 表 了 一 篇 文章 来 摘 述 事件 的 整个 过 程 ， 标 题 是 “第 1 步 : 发 布 
模棱两可 的 证 明 ; 第 2 步 : 欣 贤 烟火 表演 ”(Step 1: Post Elusive Prootf 
Step 2: Watch Fireworks) 。 此 时 学 术 界 的 一 致意 见 是 该 证 明 是 错误 的 ， 
且 没 有 修改 的 余地 。P/NP 问 题 的 状态 仍然 是 悬而未决 。 






































希望 这 本 书 能 让 许多 读者 了 解 到 P/NP 问 题 的 重要 性 ， 并 且 对 解决 这 个 问 
题 跃 跃 欲 试 。 我 或 励 你 试 试 ， 因 为 如 果 不 杀 目 答 试 ， 很 难 真 正 理解 一 个 
问题 是 多 么 困难 。 要 注意 本 书 并 未 正式 地 定义 PINP 问 题 ， 如 果 读 者 真 的 
想 求解 这 个 问题 ， 首 先 要 了 解 其 最 准确 的 表述 。 本 书 的 网 站 上 提供 了 几 
个 很 好 的 资源 ， 供 读者 了 解 PNP 问题 和 各 种 求解 尝试 的 技术 细节 以 及 公 
理化 描述 。 


假设 你 真 的 找到 了 P/NP 问 题 的 解决 方法 ， 该 怎么 通知 克 雷 数学 研究 所 ， 
证 他 们 把 一 百 万 美元 的 文 票 寄 过 来 呢 ? 先 别 急 。 你 几乎 不 可 能 有 合理 的 
证 明 。 通 过 了 解 为 什么 你 的 证 明 可 能 不 行 ， 你 说 不 定 会 得 到 局 迪 。 


下 面 我 就 描述 一 下 那些 认为 自己 证 明了 P/NP 问 题 的 人 通常 会 犯 哪些 错 
误 。 


早 在 1550 年 ， 意 大 利 数学 家 吉 罗 拉 英 :卡尔 达 诺 给 出 了 可 能 是 第 一 个 
PzxzNP 证 明 的 反面 例子 。 卡 尔 达 话 被 认为 是 概率 论 领域 的 左 基 人 之 一 ， 
在 宣传 他 发 明 的 一 种 新 的 加 密 系 统 时 ， 他 声称 该 系统 绝对 安全 ， 因 为 密 
钥 太 多 ， 无 法 逐个 检查 。 实 际 上 这 个 系统 非常 容易 破解 ， 因 为 对 加 密 的 
消息 做 解密 分 析 时 根本 不 需要 检查 所 有 的 密 钥 。 


类 似 卡 尔 达 诡 所 犯 下 的 根本 性 错误 ， 在 现在 证 明 PzNP 的 尝试 中 屡 见 不 
鲜 。 再 次 考虑 团 问 题 。 一 类 证 明 的 思路 是 ， 任 何 试图 求解 团 问题 的 算法 
在 找 不 到 一 个 有 效 解 时 ， 都 必须 确保 不 可 能 存在 给 定 人 数 的 团 。 唯 一 可 
行 的 方式 是 检查 所 有 可 能 的 人 组 成 的 集合 ， 然 后 检查 给 定 的 集合 是 个 成 
团 。 由 于 集合 太 多 了 了， 任何 算法 都 必须 花费 特别 长 的 时 间 。 上 所 以 团 问 题 
不 存在 高 效 的 解法 。 故 PzNP。Q.E.D.(Q.E.D. 是 拉丁 短语 quod erat 
demonstrandum 的 缩写 ， 意 为 “要 展示 的 就 是 这 么 多 ”， 第 用 于 数学 证 明 
的 结尾 ， 表 示 证 明 完 毕 。) 


这 种 思路 有 很 多 的 变种 。 而 其 中 的 逻辑 漏洞 在 于 “唯一 可 行 的 方式 ”"。 算 
法 可 行 的 方式 也 许 非常 难以 捉摸 。 它 并 不 需要 按 你 认为 的 方式 工作 ， 甚 
至 完全 不 用 遵守 问题 本 身 的 内 在 结构 。 也 许 有 一 个 算法 ， 把 好 友 关 系 图 
转化 成 茶 些 奇怪 的 代数 表达 式 ， 当 且 仅 当 团 存在 时 才 存 在 茶 一 类 型 的 

解 。 虽 然 这 不 太 可 能 ， 但 是 不 能 因为 你 认为 算法 不 这 样 工 作 ， 残 排除 它 
存在 这 样 的 可 能 性 。 


很 难 让 使 用 这 种 证 明 技 巧 的 人 相信 他 (或 者 她 ， 但 是 给 出 这 些 粳 料 证 明 


























的 人 几乎 无 一 例外 全 部 都 是 男性 ) 是 不 对 的 。 他 们 总 会 反 过 来 要 我 写 出 
一 个 不 用 穷 举 就 能 解 出 团 问题 的 算法 。 我 当然 写 不 出 来 ， 能 写 出 来 不 就 
意味 痢 P=NP 了 呆 ， 况 且 这 不 太 可 能 是 真 的 。 但 证 明 的 负担 在 你 身上 ， 
要 主张 你 给 出 的 证 明 的 合理 性 ， 你 需要 论证 不 存在 以 其 他 方式 工作 的 算 
2 


而 要 证 明 P=NP,“ 只 需 ” 给 出 某 个 NP 完全 问题 的 有 效 算法 。 于 是 很 多 人 会 
给 出 团 问 题 的 一 个 算法 ， 然 后 就 说 他 们 证 明了 P=NP。 但 是 一 个 算法 本 
身 并 不 构成 一 个 证 明 。 必 须 还 要 形式 化 地 论证 该 问题 的 每 一 个 实例 ， 即 
在 所 有 可 能 的 好 友 关 系 图 上 ， 该 算法 都 能 高 效 地 运行 ， 并 给 出 正确 的 答 
案 。 而 这 些 证 明 的 尝试 要 么 没有 履 盖 所 有 可 能 的 情况 ， 要 么 本 身 就 是 错 
误 的 或 不 完整 的 。 给 出 的 算法 不 是 结果 是 错误 的 ， 就 是 在 复杂 的 实例 上 
无 法 高 效 地 运行 。 





7.4 现状 


我 们 离 证 明 PzxNP 比 以 前 更 远 了 了。 虽然 对 该 问题 了 解 更 深入 了 ， 但 从 采 
种 程度 上 讲 ， 在 未 来 一 段 时 间 内 ， 都 不 存在 未 被 尝试 过 的 明显 的 方法 和 
己 知 的 证 明 思 路 了 。 


目前 唯一 己 知 的 有 可 能 解决 NP 问 题 的 方法 ， 来 目 芝 加 哥 大 学 的 山 坦 ， 
马尔 马 利 。 他 的 工作 表明 通过 解决 代数 几何 学 《〈 它 比 高 中 的 代数 和 几何 
要 复杂 得 多 ) 这 一 数学 领域 的 茶 些 问题 ， 可 能 会 产生 PzNP 的 证 明 。 但 
是 求解 这 些 代 数 几 何 学 问题 所 需 的 数学 技术 远 远 超出 了 今天 人 类 的 数学 
技术 水 平 。 几 年 前 马尔 马 利 党 得 他 的 程序 要 100 年 才能 跑 完 。 如 今 他 认 
为 之 前 想 得 有 点 乐观 了 。 


还 要 过 多 久 我 们 才能 看 到 P/NP 问 题 真正 得 到 解决 ? 也 许 在 你 读 到 本 书 的 
时 候 这 个 问题 已 经 被 解决 了 。 但 更 有 可 能 的 是 ， 很 长 一 段 时 间 内 它 痢 无 
法 被 解决 ， 也 许 比 寓 马 大 定理 从 提出 到 解决 所 经 历 的 357 年 更 长 ， 甚 至 
有 可 能 一 直 得 不 到 解决 ， 成 为 数学 和 科学 领域 一 个 永远 的 未 解 之 谜 。 











第 8 章 ”秘密 


每 个 人 都 有 秘密 ， 从 密码 到 电子 邮件 ， 我 们 都 有 不 想 让 别人 看 到 的 东 
西 。PzNP 意 味 着 余 些 NP 问题 拥有 不 为 人 知 的 秘密 ， 无 法 很 快 找到 它 的 
答案 。1976 年 ， 惠 特 菲 尔 德 : 迪 菲 和 马丁 ' 赫 尔 受 提出 可 以 用 NP 问 题 来 隐 
藏 我 们 目 己 的 秘密 。 从 此 ， 密 码 学 这 门 研究 秘密 消 恩 的 学 科 发 生 了 质 的 
改变 。 





8.1 经 典 密码 学 简 史 

秘密 消息 的 历史 和 人 们 传递 消息 的 历史 一 样 久远 。 朱 利 叶 斯 凯撒 使 用 
过 一 个 简单 的 蔡 换 加 密 算法 ， 即 将 每 个 字母 替换 为 它 在 字母 表 位 置 往 后 
数 第 三 个 位 置 的 字母 。 


The early bird gets the worm (早起 的 鸟 儿 有 虫 吃 ) 就 变 成 了 Wkh hduob 
elug jhwv wkh zrup。 这 种 字母 蔡 换 的 加 密 方 法 被 称 为 屈 撒 密码。 
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图 8-1 凯撒 密码 


这 种 技术 在 古 罗马 非常 好 用 ， 加 过 密 的 消息 看 起 来 像 是 胡言 乱 语 ， 而 那 
时 人 们 有 限 的 技术 还 无 法 破译 这 种 密码 。 到 了 公元 9 世纪 ， 数 学 家 发 现 
了 通过 统计 字母 和 短 字 的 频率 来 破解 密码 的 方法 。 我 们 来 看 WKkh hduob 
elug jhwv wkh zrup， 注 意 其 中 字母 h 出 现 了 4 次 ， 比 其 他 字母 都 多 。 英 语 
中 出 现 频率 最 高 的 字母 是 es， 所 以 可 以 《正确 地 ) 推测 h 代 表 e。 然 后 注 
意 到 Wkh 出 现 了 2 次 ， 而 如 果 h 代 表 e， 那 么 可 以 推测 Wkh 代 表 the。 按 此 
方法 ， 很 快 就 能 破译 这 条 消息 。 


在 15 世 纪 的 意大利 文艺 复兴 时 期 ， 且 帅 : 巴 蒂 斯 塔 :阿尔 伯 带 创造 了 一 种 
更 为 复杂 的 加 密 方 法 ， 称 为 多 字母 加 密 法 (polyalphabetic cipher) ， 对 
消息 的 不 同 部 分 使 用 不 同 的 蔡 换 规则 。 这 些 密 码 在 很 长 一 段 时 间 内 都 无 
法 被 人 破解， 直到 19 世 纪 人 们 发 展 出 了 更 系统 化 的 密码 破译 方法 。 


作家 兼 诗人 埃 德 加 : 爱 伦 : 坡 也 对 密码 分 析 烦 有 研究 。1839 年 他 公开 征集 
难以 破译 的 密码 ， 以 供 他 研究 密码 破译 的 方法 。 一 年 后 ， 爱 伦 : 坡 发 表 
了 一 篇 名 为 “ 谈 谈 秘密 写作 ”(A Few Words on Secret Writing) 的 文章 ， 
他 在 其 中 声称 * 人 类 的 创造 力 无 法 创造 自身 不 能 破译 的 密码 ”。 他 在 1843 
年 的 小 说 《 金 甲 虫 》〈Tpe Gold-Bug) 中 就 有 破译 密码 的 情节 ， 它 属于 
第 一 批 描 述 密 码 的 小 说 。 


1903 年 亚 琴 : 柯 丙 : 道 尔 发 表 了 《跳舞 的 小 人 》 (The Adventure of the 


























Dancing Man) ， 这 本 小 说 讲述 了 黎 洛 元 :福尔摩斯 如 何 破译 一 个 由 火柴 
棍 小 人 构成 的 蔡 换 密码 。 


人 


图 8-2 ”跳舞 的 小 人 


随 着 机 械 时 代 的 到 来 ， 出 现 了 一 批 加 密 和 解密 消息 的 机 器 设备 。 其 中 最 
知名 的 可 能 要 数 恩 尼 格 玛 密码 机 (Enigma machine) ， 是 德国 人 亚 瑟 . 谢 
尔 比 乌 斯 在 1918 年 发 明 的 。 


恩 尼 格 玛 密码 机 有 数 个 转子 ， 在 打字 过 程 中 ， 这 些 转 子 将 字母 蔡 换 成 其 
他 的 字母 。 由 于 每 个 转子 的 转速 不 同 ， 每 一 个 字母 具有 不 同 的 答 换 规 

则 。 这 个 机 强 可 以 看 做 是 阿尔 伯 带 的 多 字母 加 密 法 的 一 个 更 复杂 的 版 

本 ， 用 它 加 密 的 消 妃 非常 难以 破译。 








图 8-3 ” 恩 尼 格 玛 密码 机 





恩 尼 格 玛 密码 机 是 第 二 次 世界 大 战 中 德军 使 用 的 主要 密码 来 源 。 在 开战 
之 前 ， 波 兰 军 事情 报 机 构 癌 英国 提供 了 该 机 器 的 描述 和 一 些 破译 技术 。 
英国 政府 随即 局 动 了 一 项 代号 为 “超级 ”(Ultra) 的 计划 来 破解 密码 。 征 
筋 的 研究 人 员 有 纵横 填 字 和 国际 象棋 高 手 ， 也 有 大 数学 家 ， 其 中 包括 计 
算 学 之 父 阿 兰 : 图 灵 。 第 一 台 可 编程 电子 计算 机 “巨人 ”(Colossus) 束 是 
在 计划 的 实施 过 程 中 诞生 的 。 温 斯 顿 :丘吉尔 曾 说 :“ 是 ‘超级 计划 让 我 
们 得 了 战争 。” 


密码 学 从 诞生 以 来 都 是 〈 而 且 将 来 也 是 ) 一 场 猫 鼠 游 戏 ， 即 密码 制造 者 
和 密码 破译 者 双方 的 斗智 斗 勇 。 但 是 在 20 世 纪 70 年 代 ， 随 着 计算 机 科学 
家 开始 构造 基于 难以 求解 的 NP 问题 的 加 密 方 法 ， 这 个 游戏 的 格局 发 生 
了 重大 变化 。 








8.2 ”现代 密码 学 


“我 们 今天 正面 临 着 一 场 密码 学 的 革命 。” 这 是 1976 年 斯 坦 福 大 学 的 惠 特 
菲尔德 : 迪 厦 和 马丁 ' 赫 尔 曼 所 发 表 的 著名 论文 中 的 开题 名 。 “廉价 电子 硬 
件 制造 技术 的 进展 将 密码 学 从 使 用 机 械 进行 计算 所 市 来 的 设计 局 限 中 解 
放出 来 ， 让 曾经 昂贵 的 高 端 加 密 设 备 变 得 成 本 低廉 ， 使 得 远程 提 区 机 、 
计算 机 终端 等 商业 化 应 用 成 为 可 能 。” 


迪 菲 和 赫 尔 曼 认识 到 了 ， 计 算 机 可 以 让 复杂 的 加 密 通 信 协 议 以 成 本 低廉 
的 软件 形态 存在 。 但 同时 计算 机 也 带 来 了 很 多 挑 成 。 随 着 计算 机 与 计算 
机 之 间 的 网 络 得 到 普及 ， 必 须要 开发 出 一 种 高 效率 且 低 成 本 的 安全 通信 
方法 。 迪 菲 和 赫 尔 曼 在 谈 到 近 十 年 来 NP 问 题 的 进展 时 说 道 : “同时 ， 
信息 论 和 计算 机 科学 的 理论 进展 很 有 和 希望 提供 一 种 安全 的 加 密 方 法 ， 从 
而 将 密码 学 这 门 古 老 的 艺术 变 为 一 门 科学 。” 


在 迪 菲 和 赫 尔 曙 之 前 的 时 代 ， 要 解密 一 条 消 奶 必须 使 用 加 密 它 的 密 钥 。 
如 果 一 位 将 军 通过 恩 尼 格 玛 密码 机 同 战 场 上 的 一 位 上 尉 发 送 消 轧 ， 双 方 
必须 事先 约定 好 机 需 的 设置 ， 即 转子 在 消 思 开头 的 初始 参数 。 上 尉 会 随 
身 携带 一 个 密码 本 ， 里 面 记录 了 每 天 更 换 的 设置 人 参数。 如果 这 个 本 子 沙 
入 敌手 ， 秘 密 通 信 就 必须 停止 ， 直 到 发 放 一 套 新 的 密码 本 。 士 兵 们 平时 
会 悉心 保管 这 些 本 子 ， 一 旦 被 俘 就 立即 销毁 它们 。 所 以 并 不 需要 经 常 更 
换 新 的 密码 本 。 


计算 机 网 络 带 来 了 新 的 挑战 ， 因 为 不 能 想当然 地 认为 网 络 是 安全 的 。20 
世纪 来 的 计算 机 网 络 通常 会 在 茶 些 区 域 通 过 普通 电话 线 来 传输 ， 而 电话 
线 是 很 容易 被 禄 听 的 。 即 使 是 今天 ， 坐 在 咖啡 迄 另 一 头 的 人 也 可 以 读 取 
你 使 用 免费 Wi-Fi 所 发 送 的 全 部 数据 。 


不 能 用 网 络 来 发 送 密 铀 ， 人 否则 之 后 的 通信 变 得 不 安全 。 在 开始 和 共 人 秘 
密 通 信 前 ， 必 须要 用 某 种 物理 的 方法 将 密 钥 送 到 那个 人 手 上 。 而 这 样 做 
的 经 济 和 时 间 成 本 都 很 高 。 


在 前 人 罗 杰 : 默 死 尔 工作 的 基础 上 ， 迪 菲 和 赫 尔 曼 提出 了 解决 这 个 问题 
的 一 种 方法 ， 他 们 称 之 为 “ 公 钥 ”加密 。 计 算 机 生成 两 把 钥匙 ， 一 把 公 
钥 ， 一 把 私 钥 。 计 算 机 自己 储存 好 私 钥 ， 绝 不 把 它 港 露 到 网 上 。 公 和 钥 则 
































通过 网 络 广 播 给 所 有 人 。 


迪 菲 和 区 尔 曼 的 想法 是 建立 这 样 一 个 密码 系统 ， 即 使 用 公 和 钥 加 密 信息 ， 
将 原始 消息 变 成 一 串 密 码 。 公 和 铀 不 能 用 来 解密 消息 ， 只 有 私 钥 可 以 解密 
消息 。 


假如 迪 菲 想 发 送 一 条 秘密 消息 "中午 进 攻 ? 给 赫 尔 曼 ， 首 先 赫 尔 曼 要 生成 
私 铀 和 公 钥 。 然 后 赫 尔 受 把 公 钥 发 送 给 迪 菲 〈 也 发 送 给 所 有 可 能 正在 监 
昕 的 人 〉， 私 钥 则 上 自己 留 着 。 然 后 迪 菲 用 赫 尔 曼 的 公 钥 把 消 筷 "中午 进 
攻 ” 加 密 为 密码 “tzljcnnfekktis”"， 并 把 密码 “tzljcnnfekktis” 发 送 给 赫 尔 曼 。 
迪 菲 在 加 密 时 不 需要 知道 私 钥 ， 只 需 使 用 公 钥 。 魏 昕 者 能 看 到 加 密 的 字 
符 串 “tzljcnnfekktis”"， 但 是 只 知道 公 钥 是 不 能 恢复 原始 消息 的 。 攻 尔 曼 
则 可 以 用 自己 的 私 钥 把 “tzljcnnfekktis” 恢 复 成 原始 的 消息 ， 即 “中 午 进 
攻 ”。 


公 钥 加 密 有 可 能 实现 吗 ? 如 果 P=NP 那 就 不 可 能 ， 因 为 会 存在 一 个 高 效 
的 算法 ， 通 过 公 钥 来 计算 出 私 钥 。 


而 即使 是 在 1976 年 ， 大 多 数 计算 机 科学 家 也 认为 PzNP， 在 此 前 提 下 公 
钥 加 密 是 可 能 的 。 迪 菲 和 赫 尔 曼 首创 了 公 钥 加 密 系统 ， 但 是 他 们 提出 的 
通信 协议 不 如 男 一 个 协议 流行 ， 该 协议 由 罗 纳 德 .李维斯 特 、 阿 迪 : 沙 米 
尔 和 伦 纳 德 . 阿 德 曼 三 位 计算 机 科学 家 于 1978 年 发 明 ， 并 以 三 人 的 姓 缩 
写 命 名 为 RSA。 


RSA 加 密 协 议 基 于 这 样 一 个 想法 ， 即 计算 乘积 容易 ， 分 解 因数 则 很 难 。 
随机 挑选 两 个 大 的 质数 ， 比 如 5 754 853 343 和 2 860 486 313， 很 容易 计 
算 其 乘积 为 16 461 679 220 973 794 359。 另 一 方面 ， 很 难 逆转 这 个 运 
算 ， 即 把 16 461 679 220 973 794 359 分 解 为 5 754 853 343 乘 以 2 860 486 
313。RSA 使 用 了 比 这 大 得 多 的 数 ， 通 常 有 几 百 位 长 。 虽 然 说 如 果 不 证 
明 PzNP， 就 无 法 证 明 因 数 分 解 本 质 上 是 一 个 难以 计算 的 问题 ， 但 大 部 
分 人 都 认为 因数 分 解 是 一 个 困难 的 问题 。 


罗 纳 德 : 李 维 斯 特 、 阿 迪 : 沙 米尔 和 伦 纳 德 . 阿 德 曼 因为 发 明 该 协议 ， 分 享 
了 2002 年 的 图 灵 奖 。 


有 一 个 小 插曲 ， 其 实 RSA 协 议 最 早 是 在 1973 年 被 克利 福 德 : ss 
的 ， 他 为 英国 政府 通信 总 部 工作 ， 该 机 构 相 当 于 美国 的 国家 安全 局 。 








个 事实 直到 1997 年 才 被 公之于众 。 


你 可 能 每 天 都 在 用 RSA 加 密 协 议 。 随 便 看 一 个 网 站 《结果 可 能 因 浏 览 
差异 而 不 同 〉。 


facebook 





图 8-4 ”Facebook 网 站 的 地 址 栏 
注意 到 https 协 议 中 的 s 以 及 后 面 的 小 锁 标 识 。 





图 8-5 ”被 标记 的 Facebook 网 站 的 地 址 栏 


s 代 表 secure〈 安 全 ) 。EFacebook 公 布 了 一 把 公 钥 。 浏 览 器 会 把 用 户 输入 
的 密码 用 公 钥 加 密 。 加 密 过 的 密码 被 发 送 给 Facebook。 所 以 咖啡 迄 里 的 
人 即使 用 笔记 本 电脑 监测 所 有 用 Wi-Fi 传 输 的 数据 ， 也 无 法 猜 出 用 户 的 
密码 。Facebook 用 私 钥 可 以 解密 用 户 的 密码 。 同 样 地 ， 用 户 的 浏览 器 也 
生成 一 对 公 钥 和 私 钥 ， 把 公 钥 发 送 给 Facebook。 这 样 Facebook 就 可 以 问 
用 户 发 送 经 过 加 密 的 好 友 状 态 更 新 数据 ， 除 了 用 户 自己 别人 都 看 不 到 。 


8.3 P=NP 下 的 密码 学 


如 果 我 们 生活 在 第 2 章 摘 述 的 “美妙 世界 ”中 ， 密 码 学 会 发 生 怎样 的 变 
化 ? 我们 很 容易 算出 5 754 853 343 和 2 860 486 313 是 否 为 质数 ， 以 及 5 
754 853 343x2 860 486 313=16 461 679 220 973 794 359。 我 们 甚至 能 在 
几 千 位 或 几 百 万 位 的 数 上 做 这 些 运 算 。 由 于 我 们 可 以 验证 因数 分 解 问 题 
的 解 ， 故 该 问题 属于 NP。 如 果 P=NP， 那 么 因数 分 解 问 题 将 变 得 能 被 高 
效 地 计算 ， 我 们 可 以 找到 几 百 万 位 数 的 质数 因子 。P=NP 将 让 RSA 协 议 
失效 。 所 有 基于 公 钥 加 密 系统 的 协议 也 都 将 失效 。P=NP 意 味 着 如 果 不 
和 对 方 事先 联系 好 ， 你 将 无 法 同 任 何人 发 送 秘密 消 恩 。 


难道 密码 学 将 在 美妙 世界 中 毫 无 用 武之 地 吗 ? 只 有 一 个 方法 可 行 ， 就 是 
一 次 性 密码 本 (one-time pad) ， 它 的 安全 性 是 理论 上 可 被 证 明 的 ， 而 
且 不 依赖 于 NP 问 题 的 困难 程度 。 假 设 艾 莉 丝 有 一 个 12 个 字符 的 密码 
FIDDLESTICKS。 上 所 谓 的 密码 本 是 一 个 长 度 相 同 的 随机 字符 串 
JXORMQNAMRHC。 从 密码 和 字符 串 中 分 别 取出 第 一 位 的 字母 ，F 和 
J， 两 者 分 别 是 字母 表 中 第 6 个 和 第 10 个 字母 。 将 两 者 的 排序 相 加 得 到 
16， 然 后 用 第 16 个 字母 P 作 为 加 密 的 第 一 个 字母 。 再 分 别 取 出 第 二 位 的 
字母 ，I 和 X， 字 母 表 中 序号 分 别 为 9? 和 24， 相 加 得 到 33。 字 母 表 中 没有 
33 个 字母 ， 于 是 减 去 26， 得 到 7， 然 后 用 第 7 个 字母 G 作 为 加 密 的 第 二 个 
字母 。 以 此 类 推 ， 就 可 得 到 加 密 的 字符 串 PGSVYVGUVUSV。 艾 和 莉 丝 把 
加 密 的 字符 串 发 送 给 Facebook。Facebook 只 须 减 去 而 不 是 加 上 密码 本 中 
的 每 一 位 ， 就 可 解密 这 条 消息 。 


由 于 长 度 为 12 的 一 次 性 密码 本 和 消息 一 样 多 ， 所 有 加 密 字 符 串 的 概率 都 
是 相等 的 ， 数 学 上 无 法 通过 密码 本 对 消息 本 喘 有 任何 了 解 ， 无 论 是 否 
P=NP， 结 论 都 成 立 。 那 为 什么 我 们 不 都 用 一 次 性 密码 本 加 密 ， 而 要 使 
用 更 加 复杂 ， 而 且 有 可 能 被 破解 的 因数 分 解 加 密 方法 呢 ? 


使 用 一 次 性 密码 本 必须 十 分 小 心 。 顾 名 思 义 ， 一 次 性 密码 本 只 能 被 使 用 
一 次 。 甚 至 两 个 不 同 的 人 分 别 疝 另外 两 个 不 同 的 人 发 送 秘密 消息 ， 都 最 
好 不 要 用 同一 个 密码 本 ， 人 否则 不 能 保证 这 两 条 消息 的 安全 性 。 每 个 密码 
本 都 至 少 要 和 消息 一 样 长 。 没 有 公 钥 和 私 钥 之 分 ， 只 有 一 份 共享 的 私 铀 
( 即 密 码 本 JXORMQNAMRHC) 。Facebook 和 艾 莉 丝 都 必须 知道 密码 
本 ， 但 如 果 先 听 者 知道 了 密码 本 的 一 小 部 分 ， 他 就 能 获知 部 分 的 消息 。 


























Facebook 需 要 把 密码 本 以 某 种 别人 看 不 到 的 方式 交 给 艾 和 莉 丝 〈 反 过 来 也 
是 如 此 ) 。 由 于 人 们 能 监听 互联 网 通信 ， 上 所 以 Facebook 或 某 个 受信 任 的 
第 三 方 不 得 不 将 密码 本 存在 U 术 或 者 其 他 物理 设备 中 然后 交 给 芯 烛 丝 。 
我 能 想象 ， 美 妙 世 界 中 的 芯 莉 丝 会 从 杂货 店 买 一 个 密封 的 U 盘 ， 里 面 装 
满 了 一 次 性 密码 本 。U 术 会 由 某 些 受信 任 的 组 织 来 生产 (美国 政 

府 ? ) ， 并 保证 以 安全 的 方式 将 同样 的 密码 本 发 送 给 Facebook 或 其 他 公 
司 。 


Facebook 也 可 以 用 量子 力学 来 生成 密码 本 并 将 其 传输 给 艾 莉 丝 。 我 们 在 
下 一 章 会 讲 讲 量 子 密码 学 ， 但 这 个 方法 可 能 会 因为 成 本 过 高 而 无 法 被 广 
泛 使 用 。 














8.4 零 知 识 数 独 
鲍 勃 在 午餐 时 间 尝 试 解 开 一 道 当天 报纸 上 的 数 独 谜 题 。 

















图 8-6” 零 知识 数 独 


鲍 动 痛 百 地 喊 道 :“ 报 纸 一 定 弄 错 了 ， 这 个 数 独 不 可 能 有 解 ! ”他 的 同事 
区 灯丝 听 到 了 ， 过 来 看 了 一 眼 。 她 在 早 班车 上 解 出 了 同一 遭 题 ， 所 以 她 
知道 饮 勃 是 错 的 。 艾 莉 丝 的 解 如 下 。 








图 8-7” 零 知识 数 独 的 解 


鲍 动 正 打 算 放 弃 这 个 谈 题 ， 于 是 艾 莉 丝 说 她 能 解 出 这 道 题 ， 但 鲍 动 不 相 
信 。 艾 莉 丝 知道 鲍 动 看 到 明天 公布 在 报纸 上 的 答案 时 将 会 很 泪 形 ， 所 以 
她 想 让 鲍 动 继续 尝试 下 去 。 她 可 以 辣 鲍 劲 展示 自己 的 答 采 ， 但 这 将 毁 挥 
鲍 动 破解 谈 题 的 乐趣 。 艾 莉 丝 想 在 不 透露 任何 答 采 信息 的 前 提 下 ， 让 鲍 
玛 相 信 这 个 数 独 谈 题 是 有 人 解 的 。 


幸运 的 是 艾 莉 丝 在 大 学 里 主 修 计算 机 科学 ， 她 知道 零 知 识 证 明 。 她 设计 
了 如 下 这 个 方案 。 


首先 ， 艾 莉 丝 回 到 自己 的 办 公 隔 间 ， 不 让 鲍 动 看 见 她 。 艾 莉 丝 随机 重新 
排列 了 1 一 9 的 数字 。 











图 8-8 ”数字 


然后 她 把 自己 的 解 按 上 表 进 行 数字 但 换 ( 用 2 代 蔡 1，3 代 丛 9， 等 等 ) ， 
然后 把 结果 写 到 一 大 张 纸 上 。 





图 8-9 经 过 重新 排列 的 零 知 识 数 独 


然后 艾 莉 丝 仔 细 地 把 纸 覃 成 81 片 ， 每 片上 有 一 个 数字 。 她 把 每 片 纸 放 到 
一 个 小 袋子 里 ， 并 把 袋子 按 数 字 原 来 的 顺序 放 在 一 个 空白 的 网 格 上 。 
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图 8-10 被 遮 兰 的 零 知 识 数 独 
最 左上 角 的 袋子 里 装着 数字 2， 它 右边 的 袋子 装着 数字 3， 等 等 。 


芯 莉 丝 小 心地 把 网 格 和 袋子 带 到 鲍 动 那里 ， 解 释 了 刚才 她 做 的 事情 〈 没 
有 透露 数字 重 排 前 后 的 对 应 关系 〉， 并 让 鲍 动 从 28 个 检验 方法 中 选择 一 
种 。 














。 从 9 行 中 选择 一 行 ， 打 开 那 行 的 所 有 袋子 。 

。 从 9 列 中 选择 一 列 ， 打 开 那 列 的 所 有 袋子 。 

。 从 9 个 3x3 的 方 格 中 选择 一 个 ， 打 开 里 面 的 所 有 袋子 。 

。 选择 那些 位 于 原来 谜 题 中 已 知 数字 位 置 上 的 袋子 ， 并 打开 它们 。 


假如 鲍 动 选择 了 打开 第 3 行 的 所 有 袋子 。 他 看 到 的 如 下 图 所 示 。 
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图 8-11 打开 一 行 的 零 知 识 数 独 

如 果 艾 莉 丝 有 一 个 解 ， 并 且 做 了 她 说 的 那些 操作 ， 那 么 鲍 勃 看 到 的 应 该 
是 1 一 9 这 几 个 数字 不 重复 的 随机 排列 。 如 果 饱 勃 看 到 两 个 相同 的 数字 ， 
那 他 就 知道 艾 莉 丝 作 浆 了 ， 但 是 这 里 艾 莉 丝 通过 了 测试 。 

鲍 勃 若 选择 列 或 方 格 也 有 同样 的 检验 策略 。 


如 果 鲍 动 选择 最 后 一 种 检验 方法 ， 即 “选择 那些 处 在 原来 谈 题 中 已 知 数 
字 位 置 上 的 袋子 ， 并 打开 它们 ”。 他 看 到 的 如 下 图 所 示 。 
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图 8-12 ”打开 已 知 数字 对 应 位 置 的 零 知 识 数 独 





当 且 仅 当 鲍 劲 选择 做 这 项 测试 时 ， 艾 莉 丝 会 把 数字 重 排 前 后 的 对 应 关系 
表 展 示 给 鲍 动 看 。 


重 排 前 重 排 后 





图 8-13 ”数字 


然后 鲍 勃 就 可 以 检查 打开 位 置 的 数字 与 恋 题 中 原来 已 知 数字 的 对 应 关系 
是 否 如 表 中 所 示 。 根 据 此 表 ， 原 题 中 的 数字 9 应 该 对 应 袋 中 的 数字 3， 果 
然 如 此 。 

如 果 艾 莉 丝 真 的 有 一 个 解 并 且 做 了 她 说 的 那些 操作 ， 她 就 会 通过 所 有 的 
测试 。 鲍 勃 从 中 得 知 了 什么 ? 如 果 鲍 勃 选 择 查看 某 一 行 、 列 或 方块 ， 他 
只 能 够 看 到 随机 排列 的 1~9， 没 有 任何 对 解 题 有 用 的 信息 。 


如 琳 鲍 动 选择 了 最 后 一 个 测试 ， 他 会 看 到 原来 迹 题 的 一 个 随机 重 排 ， 也 














没有 任何 对 解 题 有 用 的 信息 。 


要 是 艾 莉 丝 没 有 一 个 真正 的 解 会 怎样 昵 ? 那 无 论 艾 莉 丝 怎么 做 ， 都 不 可 
能 通过 鲍 勃 可 能 选择 的 所 有 测试 。 如 果 鲍 勃 随机 选择 的 话 ， 艾 莉 丝 有 至 
少 1/28〔 即 3.57%) 的 概率 被 抓 到 作 浆 。 听 起 来 这 个 概率 插 低 的 ， 但 如 
果 艾 莉 丝 和 饱 勃 重复 83 次 测试 〈 每 次 都 选择 一 个 新 的 数字 对 应 关系 ) ， 
艾 莉 丝 至 少 有 1 次 不 能 通过 测试 的 概率 将 超过 95%6。 


鲍 动 终于 相信 获 莉 丝 解 出 了 这 道 数 独 谜 题 ， 但 是 他 得 到 的 是 关于 解 
的 “ 零 知 识 "， 即 除了 知道 存在 一 个 解 之 外 一 无 所 知 。 鲍 勃 可 以 继续 求解 
这 道 谜 题 ， 并 相信 它 是 有 解 的 ， 但 这 对 于 找到 答案 没有 任何 帮助 。 


在 这 个 例子 里 ， 鲍 动 不 愿 意 了 解 艾 莉 丝 的 解 的 任何 细 市 。 但 在 理论 上 ， 
鲍 动 可 以 通过 抓 起 所 有 侥 子 并 打开 它们 来 作 浆 。 为 了 避免 这 种 情况 ， 艾 
莉 丝 可 以 用 上 锁 的 箱子 来 代 蔡 袋 子 ， 并 且 只 给 鲍 动 他 选择 的 那些 箱子 的 
钥匙 。 


要 是 鲍 勃 和 艾 莉 丝 不 在 同一 个 办 公 室 ， 而 是 位 于 不 同 的 城市 呢 ? 他 们 仍 
可 以 轻松 地 通过 电话 或 电子 邮件 交流 ， 但 是 怎么 来 表示 袋子 呢 ? 他 们 可 
以 使 用 简单 的 加 密 技 术 。 艾 莉 丝 为 每 一 个 袋子 选 一 个 不 同 的 随机 大 数 
字 ， 其 最 后 一 位 和 袋子 里 的 数字 相同 ， 比 如 为 装 有 数字 2 的 袋子 选择 3 
682 502。 然 后 艾 莉 丝 用 她 的 公 钥 为 这 些 数字 加 密 ， 把 它们 发 送 给 饱 
勃 。 鲍 勃 选 好 做 哪 项 测试 后 ， 艾 莉 丝 给 出 鲍 勃 选择 的 袋子 对 应 的 解密 后 
的 值 。 鲍 勃 可 以 用 艾 莉 丝 的 公 钥 重新 加 密 这 些 数字 ， 然 后 检查 是 否 与 之 
前 发 送 的 加 密 值 相符 。 


正如 我 们 在 第 4 章 看 到 的 ， 数 独 是 NP 完全 问题 ， 即 每 一 个 NP 问题 都 能 归 
约 到 数 独 问题 。 所 以 我 们 就 自动 有 了 每 一 个 NP 问题 的 零 知识 系统 。 艾 
和 莉 丝 可 以 说 服 鲍 勃 在 敌 友 国 存在 一 个 很 大 的 团 ， 可 以 用 三 种 颜色 填充 某 
张 地 图 ， 或 存在 一 条 很 短 的 旅行 商 路 线 ， 同 时 只 透露 团 、 填 色 方 法 或 路 
线 的 零 知 识 ， 即 它们 是 存在 的 这 个 事实 。 


密码 学 攻击 中 常用 的 方法 是 通过 冒充 别人 来 壹 混 过 天 。 零 知识 证 明 则 提 
供 了 一 种 防卫 这 种 身份 欺骗 的 方法 。 艾 莉 丝 使 用 自己 的 公 钥 加 密 一 些 随 
机 选择 的 个 人 机 密 信 息 。 艾 莉 丝 想 向 鲍 动 证 明 她 的 喘 份 。 如 果 她 直接 把 
这 些 秘密 告诉 鲍 动 ， 那 么 理论 上 鲍 动 就 有 了 冒充 艾 莉 丝 的 机 会 。 而 如 果 
艾 莉 丝 提 供 的 是 一 些 零 知识 证 明 ， 那 么 她 不 仅 能 让 鲍 动 相信 她 知道 这 些 



























































秘密 ， 更 重要 的 是 没有 透露 目 己 的 任何 秘密 。 这 样 鲍 劲 就 能 在 不 知道 艾 
和 莉 丝 个 人 机 蜜 信息 的 前 提 下 确认 对 方 的 身份 。 


8.5” 玩 游戏 


鲍 攻 和 艾 莉 丝 正在 商量 晚餐 去 哪里 吃 。 鲍 有 劲 想 吃 牛排 ， 而 艾 莉 丝 想 吃 
鱼 。 他 们 决定 抛 硬币 来 选择 餐馆 。 鲍 勃 抛 起 硬币 ， 然 后 把 它 扣 在 用 膊 
上 。 区 莉 丝 猜 正 面 。 鲍 勃 拿 开 盖 在 硬币 上 的 手 ， 是 反面 ， 于 是 两 人 去 吃 
牛排 。 


听 起 来 扭 公平， 不 过 要 是 艾 莉 丝 和 鲍 勃 是 通过 电话 或 互联 网 联络 怎么 
办 ? 鲍 勃 可 能 会 对 硬币 结果 撒谎， 甚至 根本 不 抛 硬币 。 艾 莉 丝 如 何 才能 
确认 过 程 是 公平 的 ? 


一 个 办 法 是 用 公开 的 随机 信息 。 鲍 忒 和 艾 莉 丝 可 以 商定 如 果 当 天 道 琢 斯 
工业 指数 的 收盘 价 最 后 一 位 是 奇效， 那么 由 鲍 劲 来 选 餐 厅 ， 如 果 是 偶数 
则 由 艾 莉 丝 说 了 算 。 但 这 个 方法 在 星期 六 就 失效 了 ， 股 市 不 开盘 。 


这 里 介绍 一 种 使 用 密码 学 的 方法 ， 用 到 了 我 们 在 本 章 前 面 讲 到 的 公 钥 加 
密 。 首 先 由 鲍 过 生成 公 铀 和 私 铀 ， 然 后 随机 选 一 个 数 ， 如 69 441 251 
920 931 124， 把 它 用 公 钥 加 密 。 鲍 勃 把 公 钥 和 加 密 过 的 消息 发 给 艾 莉 
2 


然后 轮 到 艾 莉 丝 来 猜 鲍 勃 的 数字 是 奇数 还 是 偶数 ， 并 把 结果 发 给 鲍 勃 。 
之 后 鲍 勃 把 私 钥 发 送 给 艾 莉 丝 ， 后 者 用 它 解 密 信息 ， 发 现 鲍 勃 选 定 的 数 
字 是 69 441 251 920 931 124。 若 艾 莉 丝 猜 的 是 偶数 ， 那 她 就 赢 了 ;， 如果 
她 猜 的 是 奇数 ， 那 鲍 勃 就 赢 了 。 


为 什么 这 个 方案 能 奏效 呢 ? 在 艾 莉 丝 选 择 猜 奇 数 或 偶数 之 前 ， 鲍 勃 选 好 
了 一 个 数 69 441 251 920 931 124。 艾 烙 丝 在 猜 的 时 候 不 知道 鲍 动 选 的 是 
什么 数 。 芯 烙 丝 只 能 看 见 加 密 过 的 消 恩 ， 除 非 能 破解 密码 ， 盏 则 她 对 鲍 
勃 选择 的 数 一 无 所 知 。 所 以 艾 莉 丝 只 能 随便 狂 。 另 一 方面 ， 饱 勃 无 法 改 
变 选 定 的 数 ， 因 为 之 前 已 经 把 它 的 加 密 版 本 发 给 艾 莉 丝 了 。 艾 莉 丝 猜 完 
后 鲍 勃 通过 发 送 私 钥 来 公布 答案 。 如 果 双 方 都 随机 地 进行 游戏 ， 那 么 胜 
率 应 该 是 五 五 平分 的 。 只 要 公 钥 加 密 系 统 是 安全 的 ， 就 没有 人 能 作 浆 。 


抛 硬币 这 个 游戏 太 简 单 了 ， 那 么 对 于 复杂 点 的 游戏 情况 又 如 何 呢 ? 




















鲍 艺 和 艾 莉 丝 能 通过 电话 下 国际 象棋 吗 ? 可 以 ， 而 且 很 容易 
轮流 用 标准 国际 象棋 记 谱 法 告诉 对 方 目 己 的 行动 即 可 。 


他 们 能 下 西洋 双 陆 棋 (backgammon) 或 强手 棋 〈Monopoly) 吗 ? 鲍 勃 
如 何 括 般 子 才能 让 艾 烙 丝 信 服 ? 他 们 可 以 采用 一 套 掷 般 子 的 协议 ， 原 理 
类 似 于 上 面 的 抛 便 币 协议 。 


他 们 可 以 玩 扑 死 牌 或 其 他 牌 类 游戏 吗 ? 这 回 情况 就 变 得 复杂 得 多 了 。 芝 
莉 丝 需 要 得 到 一 些 随机 选择 的 牌 ， 只 有 她 能 看 见 ， 鲍 劲 看 不 见 ; 鲍 动 也 
要 有 艾 莉 丝 看 不 到 的 一 些 牌 。 还 要 有 一 些 两 个 玩家 都 能 看 到 的 牌 ， 以 及 
一 些 两 人 现在 看 不 到 ， 但 之 后 会 让 一 个 或 两 个 玩家 看 到 的 牌 。 


好 多 网 站 都 能 让 你 玩 扑克 有 牌 ， 但 这 些 网 站 本 号 充 当 了 受信 任 的 第 三 方 ， 
由 他 们 来 发 牌 或 将 脾 展 示 给 各 个 玩家 的 浏览 嚣 。 


在 没有 受信 任 的 第 三 方 的 情况 下 ， 鲍 动 和 艾 莉 丝 还 能 玩 扑 殉 牌 吗 ? 在 20 
世纪 70 年 代 和 80 年 代 ， 密 码 学 家 设计 了 许多 种 通过 电话 或 网 络 进行 双人 
或 多 人 牌 关 游 戏 的 方案 ， 每 个 玩家 都 有 目 己 的 私 铀 和 公 铀 ， 并 需要 对 加 
密 的 信息 再 进行 一 次 加 密 。 


20 世 纪 80 年 代 和 90 年 代 ， 密 码 学 家 研发 出 了 非常 通用 的 技术 ， 让 任意 需 
要 跟 受 信任 对 手 玩 的 游戏 都 能 通过 互联 网 进行 ， 即 使 没有 受信 任 的 对 手 
也 可 以 。 这 些 方法 既 用 到 了 加 蜜 技术， 又 使 用 了 零 知 识 证 明 。 这 些 通信 
协议 相当 复杂 ， 而 且 很 少 被 实际 应 用 。 现 实 中 人 们 要 么 依靠 受信 任 的 网 
站 ， 要 么 会 及 用 一 些 针 对 某 个 特定 目的 而 设计 的 通信 协议 。 


每 个 人 
































8.6 ”在 云 上 进行 加 密 计算 


假如 艾 烙 丝 需 要 对 敏感 数据 进行 计算 ， 而 鲍 动 是 云 计算 服务 的 提供 商 。 
艾 莉 丝 可 以 通过 鲍 动 的 公 钥 把 数据 传送 给 鲍 劲 。 鲍 动 解 密 数 据 ， 做 完 计 
算 ， 把 结果 用 艾 莉 丝 的 公 钥 加 和 密 后 回 传 给 艾 莉 丝 。 如 果 艾 莉 丝 和 鲍 动 使 
用 的 公 钥 加 密 协 议 足 够 安全 ， 疫 有 人 可 以 从 中 得 知 艾 莉 丝 的 数据 。 如 果 
艾 烙 丝 信 任 鲍 动 那 没 问题 ， 但 如 末 她 对 鲍 动 不 够 信任 ， 想 让 数据 对 鲍 动 
也 是 保密 的 ， 还 能 进行 云 计 算 吗 ? 


解决 这 个 问题 需要 使 用 所 谓 完 全 同 态 (homomorphic) 的 加 密 方法 。 
RSA 协 议 中 ， 如 果 把 两 个 数 〈 如 28 和 45) 经 过 加 密 的 版 本 相 乘 ， 就 可 得 
到 它们 的 乘积 1260 的 加 密 版 本 。 不 需要 知道 原始 的 数字 ， 就 能 通过 加 密 
数字 计算 其 乘积 的 加 密 版 本 。 男 一 方面 ，RSA 上 的 加 法 不 满足 这 个 条 
件 。 人 们 不 知道 有 什么 方法 可 以 由 28 和 45 的 加 密 版 本 得 到 其 和 73 的 加 密 
版 本 。 


大 多 数 计 算 可 以 用 数 之 间 的 和 与 积 来 表示 。 和 类 似 于 或 门 ， 积 类 似 于 与 
门 ， 这 样 就 能 用 和 与 积 来 构造 电路 。 完 全 同 态 的 加 密 方法 允许 我 们 直接 
用 加 密 后 的 数字 来 计算 加 密 后 的 和 与 积 。 使 用 这 种 方法 可 以 从 加 密 的 输 
入 直接 得 到 加 密 的 输出 ， 不 需要 任何 附加 的 通信 过 程 。 


艾 莉 丝 可 以 采用 完全 同 态 的 加 符 方 采 ， 把 加 密 过 的 数据 上 传 到 鲍 动 的 计 
算 机 。 印 动 在 执行 艾 烙 丝 指 定 的 计算 时 ， 不 需要 知道 艾 莉 丝 的 原始 数 

据 。 鲍 动 得 到 的 计算 结果 是 经 过 加 密 的 版 本 ， 他 自己 无 法 解密 这 些 结 

果 ， 只 有 艾 莉 丝 能 在 下 载 之 后 用 上 自己 的 私 钥 进 行 解密 。 


很 多 年 来 ， 密 码 学 家 都 无 法 实现 完全 同 态 加 密 ， 很 多 人 曾 认为 它 不 可 能 
实现 。2009 年 ， 斯 坦 福 大 学 的 研究 生 克 雷 格 . 金 特 里 发 现 了 一 个 实现 完 
全 同 态 加 密 的 方案 。 这 个 方案 的 效率 还 无 法 达到 实用 要 求 ， 但 可 以 肯定 
的 是 ， 它 开启 了 全 新 的 可 能 性 之 门 ， 不 久 的 将 来 就 会 出 现 更 好 的 加 密 协 
议 。 

















8.7 ”创造 随机 性 


石 尖 剪刀 布 是 一 个 很 流行 的 小 游戏 ， 参 与 游戏 的 两 个 人 用 手势 比划 出 驴 
刀 、 石 头 或 布 的 样子 。 


石 尖 能 砸 坏 瘟 妨 ， 于 是 出 石 尖 的 人 启 出 斑 刀 的 人 。 甬 刀 能 前 碎 布 ， 布 能 
包 住 石 头 。 如 果 两 人 出 同样 的 手势 ， 那 么 算 平 手 。 


如 何 来 选择 玩 石头 勇 刀 布 最 好 的 策略 ? 如 条 你 能 比较 准确 地 预 训 对 手 ， 
那 就 根据 其 行动 来 决定 做 出 什么 手势 。 但 是 让 我 们 反 过 来 想 想 ， 如 果 对 
手 看 穿 了 你 的 思维 习惯 ， 你 会 一 直 输 吗 ? 


如 果 你 总 是 随机 选择 手势 就 不 会 。 你 等 概率 地 出 勇 刀 、 石 头 和 布 ， 那 么 
不 论 你 的 对 手 做 什么 ， 你 总 会 有 三 分 之 一 的 时 间 启 、 三 分 之 一 的 时 间 
输 ， 以 及 三 分 之 一 的 时 间 平 局 。 话 虽 如 此 ， 人 类 很 难 做 出 完全 随机 的 选 
择 ， 这 才 使 得 在 多 次 进行 石头 斑 刀 布 的 游戏 时 有 真正 的 技巧 性 可 言 。 
































石头 赢 剪 刀 








图 8-14 石头 剪刀 布 


类 似 地 ， 密 人 码 学 也 要 求 有 随机 性 。 本 章 中 谈 到 的 每 一 个 加 密 方法 都 涉及 
随机 选择 ， 以 让 信息 对 窃听 者 和 对 手 保 密 。 如 果 数 字 不 是 完全 随机 的 ， 
那么 对 手 将 会 占 优 势 ， 甚 至 对 于 一 次 性 密码 本 这 种 安全 的 加 密 方法 也 是 
如 此 。 


计算 机 如 何 生成 随机 数 呢 ? 计算 机 不 会 抛 重 币 ， 即 使 它 会 ， 人 硬币 也 同样 
遵循 物理 法 则 ， 不 能 实现 真正 的 随机 。 人 们 也 许 能 从 量子 效应 中 抽取 随 
机 性 ， 但 目前 还 不 能 在 日 常 计算 中 实际 大 量 使 用 这 种 方法 。 


人 们 抛 人 硬币 ， 撕 角子 ， 洗 脾 或 转动 轮 盘 ， 部 是 为 了 创造 随机 性 。 所 有 这 
些 操 作 都 直接 遵循 物理 法 则 ， 赌 场 完全 不 会 有 赔钱 的 风险 。 轮 盘 赌 中 小 
球 和 转盘 的 复杂 区 互 作用 ， 使 得 预测 某 次 转动 的 结果 在 计算 上 几乎 是 不 
可 能 实现 的 ， 一 般 人 几乎 无 法 将 轮 盘 赌 结果 的 分 布 和 完全 的 随机 行为 区 
分 开 来 。 


计算 机 也 采用 了 这 样 的 方法 。 它 并 不 直接 拥有 完全 随机 的 比特 ， 而 是 通 
过 执行 共 些 结果 难以 预测 的 操作 来 生成 “ 伪 随 机 数 ”。 密 码 学 和 随机 数 生 
成 之 间 有 直接 的 联系 。 经 过 加 密 的 消息 在 没有 密 钥 的 对 手 看 来 应 该 是 随 
机 的 。 许 多 加 密 搁 术 可 以 被 改造 为 很 好 的 随机 数 生成 占 。 


你 的 计算 机 基本 不 用 这 些 系统 来 生成 伪 随 机 数 ， 而 是 用 一 些 更 为 高 效 的 
系统 ， 这 些 系 统 通常 效果 不 错 ， 但 在 理论 上 不 能 保证 安全 。 如 何在 更 少 
的 计算 时 间 和 更 高 的 盆 随 机 性 之 间 权 衡 是 一 个 两 难 的 问题 。 


伪 随 机 数 生成 器 只 在 问题 复杂 到 一 定 程度 时 才 有 效 。 如 果 P=NP， 那 每 
一 个 计算 上 局 效 的 过 程 都 能 在 菏 种 程度 上 被 逆转 ， 这 样 ， 生 成 计算 上 随 
机 的 抛 硬币 事件 就 很 难 了 ， 甚 至 是 不 可 能 的 。 石 头 筋 刀 布 在 美妙 世界 将 
不 再 是 一 个 靠 运气 的 游戏 。 














8.8 ”持续 的 挑战 


我 们 目前 使 用 的 是 基于 因数 分 解 等 NP 问题 的 公 钥 加 密 系统 。 艾 莉 丝 很 
容易 就 能 生成 一 个 只 有 她 知道 因子 且 很 难 被 因数 分 解 的 大 数 ， 只 要 随机 
选择 两 个 大 的 质数 ， 把 它们 相 乘 就 可 以 了 。 


人 们 还 不 知道 因数 分 解 是 否 为 NP 完全 问题 ， 但 倾向 认为 不 是 。 即 使 它 
古 NP 完 全 的 ，PzNP 也 只 是 意味 着 存在 作 些 难以 因数 分 解 的 大 数 。 随 机 
选择 的 数字 仍然 有 可 能 容易 被 因数 分 解 。 


现代 密码 学 构建 在 NP 完全 问题 的 困难 性 以 及 PzNP 的 假设 之 上 ， 这 是 该 
学 科目 前 面临 的 心腹 之 患 。 


20 世 纪 70 年 代 迪 菲 和 区 尔 曼 的 工作 彻 后 改变 了 密码 学 ， 让 我 们 能 直接 基 
于 求解 菏 些 问题 的 困难 程度 来 构造 加 密 协 议 。 纵 横 填 字 高 手 、 国 际 象棋 
大 师 和 聪明 的 数学 家 再 也 不 能 找到 直接 破解 这 些 密码 的 方法 了 。 


而 猫 鼠 游戏 并 没有 因此 终止 。 既 然 不 能 直接 地 破解 密码 ， 黑 客 转 而 攻击 
其 他 的 薄弱 坏 证 。 艾 莉 丝 和 鲍 劲 可 能 没有 在 通信 协议 中 使 用 很 好 的 随机 
数 。 黑 客 可 能 会 利用 艾 莉 丝 使 用 的 浏览 器 或 操作 系统 的 设计 缺陷 来 入 侵 
她 的 计算 机 。 艾 莉 丝 可 能 被 蒙骗 ， 将 私 钥 告 诉 其 他 人 。 艾 莉 丝 选择 的 密 
码 可 能 不 够 强壮 ， 从 而 让 黑客 有 了 可 乘 之 机 。 


除了 通常 能 看 到 和 想到 的 通信 数据 之 外 ， 黑 客 还 能 利用 一 些 其 他 的 信息 
来 破解 密码 。 比 如 计算 花费 的 时 间 与 编码 的 消 轧 也 许 是 相关 的 ， 黑 客 可 
以 利用 这 一 点 。 黑 客 还 可 能 会 破坏 系统 的 一 部 分 ， 比 如 把 智能 卡 扔 进 微 
波 炉 加 热 ， 这 样 做 有 可 能 使 受 损 的 计算 必 片 不 再 保障 数据 的 安全 性 。 


人 们 也 许 会 发 明理 论 上 牢 不 可 破 的 加 密 方 法 ， 但 基本 上 永远 都 不 可 能 实 
现 绝对 不 会 泄密 的 保密 系统 。 














第 9 音量 子 


1982 年 ， 诡 贝尔 奖 得 主 物理 学 家 理 查 德 . 费 曼 发 现 ， 不 存在 简单 的 方法 
可 以 利用 电子 计算 机 对 量子 物理 系统 进行 简单 的 仿真 。 他 把 这 个 问题 转 
化 为 一 个 机 会 ， 提 议 也 许可 以 研 友 一 种 基于 量子 力学 的 计算 设备 ， 其 计 
算 效率 比 传统 的 计算 机 更 局。 在 接 下 来 的 十 年 ， 计 算 机 科学 家 和 物理 学 
家 经 过 合作 ， 在 理论 上 证 明了 量子 计算 机 能 比 普 通 计算 机 更 快 地 解决 某 
些 问题 ， 例 如 因数 分 解 。 至 于 是 人 否 能 建造 出 真正 可 用 的 大 型 或 中 等 规模 
的 量子 计算 机 ， 并 且 了 解 这 类 计算 机 到 底 能 做 什么 ， 不 能 做 什么 ， 仍 然 
是 意义 非凡 的 重大 挑战 。 本 章 我 们 将 探讨 量子 计算 的 力量 ， 以 及 与 之 相 
关 的 量子 密码 学 和 量子 隐形 传输 (quantum teleportation ) 。 














9.1 量子 录像 机 


汤姆 是 波士顿 人 ， 很 自然 地 ， 他 也 是 波士顿 红 袜 队 的 球迷 。 有 一 天 在 汤 
姆 上 班 的 时 候 ， 纽 约 洋 基 队 客场 对 战 波士顿 ， 他 刻意 避免 读 到 任何 关于 
比 客 的 消 奶 。 下 班 回 家 后 ， 他 订 了 一 些 披萨 饼 ， 打开 有 录像机， 开始 观赏 
儿 小 时 前 就 结束 的 这 场 比赛 。 第 9 局 末 ， 红 袜 队 在 二 垒 和 三 垒 有 人 ， 两 
人 出 局 ， 一 人 和 被 夹 杀 。 此 时 波士顿 的 强力 击 球 手 布 莱 恩 : 哈 默 走 上 本 双 
板 ， 汤 姆 十 分 希望 哈 默 能 击 中 。 汤 姆 觉得 自己 有 点 反应 过 度 了 ， 毕 葛 比 
赛 早 就 结束 了 ， 哈 默 要 么 击 中 了 ， 要 么 设 击 中 。 但 是 汤姆 不 知道 是 哪个 
结果 。 在 汤姆 看 来 ， 比 赛 的 结果 还 是 未 被 确定 的 ， 实 际 的 结果 介 于 输 和 
顾 之 间 ， 并 且 很 快 融会 癌 他 揭 开 谜底 。 


汤姆 的 真实 取决 于 他 的 观测 。 从 汤姆 的 观点 来 看 ， 只 要 他 没有 观看 到 最 
后 一 刻 ， 比 赛 就 还 没有 结束 ， 胜 者 还 未 被 确定 。 在 最 后 一 刻 之 前 ， 比 赛 
处 在 一 种 奇怪 的 状态 中 ， 介 于 红 剑 队 启 和 输 之 间 。 


洋基 队 的 铁杆 球迷 苏 姗 也 把 同一 场 比赛 用 录像 机 录 了 下 来 ， 并 且 和 汤姆 
在 同一 时 间 分 别 观看 目 己 的 录像 。 苏 姗 和 汤姆 一 样 ， 不 知道 哈 黑 是否 能 
击 中 ， 如 果 击 中 那 洋 基 队 就 输 了 。 苏 姗 脑海 中 的 比赛 也 是 不 确定 的 ， 是 
一 个 随机 性 事件 ， 直 到 她 看 完整 场 比赛 。 


苏 刀 和 汤姆 在 同一 时 刻 、 相 隔 200 瑞 里 的 两 个 地 点 观察 两 个 随机 事件 。 
然而 ， 他 们 将 看 到 一 致 的 结果 : 两 个 人 要 么 都 观测 到 哈 默 击 打 成 功 ， 要 
么 都 观测 到 他 击 打 失 败 。 不 可 能 汤姆 看 到 哈 黑 击 中 了 球 而 苏 姗 看 到 哈 默 
被 三 振 出 局 。 两 个 人 都 不 知道 结果 ， 但 都 确信 看 到 的 比赛 结果 是 一 样 
的 。 记 录 在 苏 姗 和 汤姆 的 录像 机 上 的 结果 ， 以 茶 种 方式 彼此 纠缠 在 一 
起 。 


这 和 量子 计算 有 什么 关系 ?传统 计算 机 最 基本 的 元 素 是 比特 〈bit， 
binary digit 的 简写 ) ， 它 只 能 取 两 个 值 中 的 一 个 ， 如 万 或 输 、 真 或 假 。 
而 量子 计算 机 的 基本 元 素 叫 量子 比特 (guantum bit) 。 和 只 能 取 两 个 值 
之 一 的 比特 不 同 ， 量 子 比 特 的 取 值 能 介 于 两 个 值 之 间 。 


记录 在 录像 带 上 的 棒球 比赛 并 不 是 真 的 量子 比特 ， 但 是 它们 有 一 些 共 同 
的 属性 。 汤 姆 看 球赛 时 ， 直 到 比赛 结束 ， 结 果 都 是 不 确定 的 。 而 从 他 观 





























测 到 比赛 结束 的 那 一 刻 起 ， 结 果 就 确定 了 ， 红 袜 队 不 是 说 了 就 是 输 了 ， 
不 再 介 于 两 者 之 间 。 类 似 地 ， 从 量子 比特 被 观测 到 的 那 一 刻 起 ， 它 就 变 
成 了 一 个 传统 的 比特 ， 只 能 取 两 个 值 之 一 ， 而 不 是 介 于 两 个 值 之 间 。 


量子 比特 可 以 互相 纠缠 ， 就 像 汤姆 和 苏 姗 的 录像 带 那 样 。 让 两 个 量子 比 
特 互相 纠缠 ， 这 样 它 们 在 被 观测 到 的 那 一 刻 就 总 能 给 出 相同 的 答案 。 


不 过 二 者 的 相似 性 就 到 此 为 止 了 。 量 子 比 特 能 以 复 淋 得 多 的 方式 互相 纠 
缠 ， 而 这 些 纠缠 态 可 被 操控 ， 从 而 形成 计算 能 力 。 


比赛 的 结果 是 一 个 简单 的 概率 ， 可 以 在 一 条 简单 的 直线 上 取 任 意 值 。 


波士顿 之 











波士顿 输 





图 9-1 波士顿 

五 角 星 所 处 的 位 置 代表 波 士 顿 有 30% 的 概率 会 赢 。 汤 姆 看 完了 比赛 ， 五 
角 星 要 么 左 移 到 尽头 ， 要 么 右 移 到 尽头 ， 至 于 向 哪 边 移 动 则 取决 于 比赛 
结果 。 

量子 比特 则 可 在 一 个 圆圈 上 取 值 。 


假 假 


图 9-2 量子 比特 


这 张 图 里 的 五 角 星 在 二 维 平面 中 的 坐标 是 (0.55 真 , 0.84 假 )。 量 子 比 特 也 
可 以 取 负 值 。 笑 脸 代 表 的 量子 比特 取 值 为 ( - 0.71 真 ，- 0.71 假 )。 量 子 计 
算 机 能 以 可 控 的 方式 旋转 或 翻转 这 个 圆圈 。 











一 个 量子 比特 可 用 一 个 二 维 的 圆圈 来 表示 。 两 个 量子 比特 则 需要 用 一 个 
四 维 版 本 的 圆圈 来 表示 其 状态 ， 很 难 在 这 里 画 出 来 ， 甚 至 难以 想象 。30 
个 量子 比特 则 需要 超过 1 万 亿 个 维度 。 


这 启发 人 们 可 以 用 量子 计算 机 的 方法 解决 NP 问题 。 想 想 从 2 万 敌 友 国 居 
民 中 找 出 50 人 的 团 的 问题 。 我 们 能 用 大 概 500 个 量子 比特 表示 出 所 有 可 
能 的 50 人 的 集合 。 然 后 可 以 同时 并 行 地 处 理 所 有 的 集合 ， 并 通过 适当 的 
旋转 和 翻转 操作 标记 出 其 中 能 够 组 成 团 的 那些 集合 。 


我 们 现在 有 了 一 个 “量子 态 ”， 即 大 概 3x10”9 〈3 后 面 跟 150 个 0) 组 敌 友 
国 居民 的 组 合 状 态 ， 其 中 某 些 被 标记 为 团 。 如 果 能 用 某 种 方式 很 快 地 把 
这 些 团 从 量子 态 中 抽取 出 来 ， 我 们 束 能 用 量子 方法 快速 解决 团 问 题 以 及 
每 一 个 其 他 的 NP 问题 。 当 我 们 观测 这 个 量子 状态 的 时 候 〈 束 好 比 看 到 
录像 带 上 比赛 的 结尾 ) ， 我 们 只 能 看 到 一 个 结果 ， 即 敌 友 国 中 的 一 群 
人 ， 而 很 有 可 能 这 群 人 不 会 组 成 一 个 团 。 


我 们 需要 茶 种 方式 ， 证 组 成 团 的 人 群集 合 脱颖而出 ， 从 而 更 有 可 能 被 观 
汕 到 。 这 可 以 用 量子 操作 来 实现 。 最 答 的 方法 将 使 用 和 集合 的 个 数 相等 
次 数 的 量子 操作 ， 即 大 概 3x102 次 的 量子 操作 ， 完 全 没有 体现 使 用 量子 
计算 的 优势 。1996 年 ， 在 新 泽 西 州 贝尔 实验 室 工 作 的 洛 夫 : 格 罗 佛 发 明 

了 一 种 更 高 明 的 量子 算法 , “仅仅” 使 用 2x10” 次 的 量子 操作 。 即 使 我 们 
每 秒 做 1 万 亿 次 量子 操作 ， 上 所 需 时 间 也 大 致 是 当前 宇宙 年 龄 的 5 倍 。 


有 某 些 证 据 表 明 格 罗 佛 的 算法 是 使 用 量子 计算 机 来 求解 NP 完全 问题 所 
能 达到 的 最 好 结果 ， 所 以 P=NP 的 量子 版 本 也 不 太 可 能 成 并 。 即 使 物理 
学 家 们 成 功 造 出 了 量子 计算 机 ， 它 还 是 无 法 解决 我 们 面临 的 最 难 的 问 


题 。 


这 并 不 意味 看 量子 计算 机 就 没有 用 了 。 它 能 对 纳米 级 别 的 物理 系统 有 效 
地 进行 复杂 的 仿真 ， 这 将 有 助 于 揭 开 宇宙 的 一 些 未 解 之 谜 。 量 子 计 算 机 
还 能 求解 某 些 人 们 无 法 用 传统 计算 机 有 效 解决 的 NP 问 题 。 


1994 年 ， 贝 尔 实验 室 的 另 一 名 研究 人 员 彼 得 : 肖 尔 意识 到 ， 量 子 计 算 机 
能 对 数字 进行 因数 分 解 ， 例 如 对 于 数字 16 461 679 220 973 794 359， 找 
到 两 个 数 5 754 853 343 和 2 860 486 313， 并 有 5 754 853 343x2 860 486 
313=16 461 679 220 973 794 359。 他 的 算法 工作 在 快速 的 量子 计算 机 


























上 ， 对 几 百 位 甚至 几 千 位 的 大 数 都 有 效 。 搜 索 一 个 数 的 因子 问题 有 者 展 
好 的 代数 结构 ， 可 被 量子 计算 机 利用 。 尽 管 我 们 认为 因数 分 解 对 于 今天 
的 计算 机 是 很 难 的 问题 ,量子 计 算 机 则 能 够 借 此 克服 这 些 困难 ， 分 解 很 
大 的 数字 。 而 NP 完 全 问题 则 缺乏 这 种 展 好 的 代数 结构 ， 故 首尔 的 算法 
对 通用 的 NP 问 题 是 无 效 的 。 


当然 ， 我 们 能 真正 使 用 格 罗 佛 或 肖 尔 的 算法 的 前 提 是 : 有 一 个 能 工作 的 
量子 计算 机 。 为 解决 今天 的 机 器 无 法 解决 的 规模 可 观 的 问题 ， 我 们 至 少 
要 上 万 个 量子 比特 彼此 纠缠 ， 并 在 几 秒 的 时 间 内 是 可 挖 的。 可惜 的 
是 ， 量 子 纠缠 态 十 分 脆弱 。 量 子 系统 和 外 界 环境 的 任何 交互 作用 都 可 能 
引起 一 次 “观测 ”， 导 致 某 些 纠缠 态 的 丧失 ， 这 对 于 精密 的 量子 计算 是 不 

可 挽回 的 灾难 。 


甚至 对 于 两 个 量子 比特 ， 目 前 物理 学 家 还 不 能 使 其 达到 完美 或 接近 完美 
的 量子 纠缠 态 。 计 算 机 科学 家 采用 所 请 量子 纠 错 的 方法 来 设计 算法 ， 以 
处 理 中 等 规模 的 量子 纠缠 。 即 使 如 此 ， 我 们 不 知道 如 何在 超过 5 个 量子 
比特 之 间 创 造 出 显 闭 数量 的 纠缠 态 。 可 能 存在 某 些 自然 界 的 基本 法 则 ， 
阻止 量子 之 间 在 一 段 足 够 长 的 时 间 内 处 于 显著 的 纠缠 态 ， 也 可 能 这 只 是 
一 个 环 手 的 工程 问题 。 我 们 还 是 让 物理 学 家 来 解决 这 个 问题 吧 。 


还 有 其 他 利用 量子 效应 来 进行 计算 的 方法 ， 如 量子 绝热 系统 ， 或 量子 退 
火 ， 而 它们 也 分 别 有 自 里 的 搁 术 和 计算 局 限 性 。 一 个 叫 D-Wave 的 公司 
宣称 建造 了 基于 这 些 技术 的 机 器 ， 但 这 些 机 器 的 计算 能 力 能 售 超 过 人 们 
的 梨 面 电脑 ， 还 有 竺 评估 。 


即使 我 们 发 现 了 建造 真正 的 量子 计算 机 的 方法 ， 这 些 机 器 仍然 是 为 特殊 
用 途 而 建造 的 ， 如 因数 分 解 或 者 量子 系统 的 仿真 。 它 们 也 许 有 助 于 破解 
密码 ， 以 及 加 深入 们 对 宇宙 的 本 质 的 了 解 ， 但 不 太 可 能 用 它们 来 求解 
NP 完 全 问题 ， 或 加 快 电子 表格 的 运行 速度 。 





























9.2 ”量子 密码 学 


我 们 第 8 章 中 讨论 的 大 部 分 密码 学 工具 的 安全 性 都 依赖 于 一 个 假设 ， 即 
因数 分 解 是 一 个 计算 上 困难 的 问题 。 任 何人 只 要 口袋 里 装着 量子 计算 

机 ， 萄 能 用 肖 尔 的 算法 把 密 钥 分 解 因 数 进而 破解 这 些 密 码 。 虽 然 现在 还 
没有 闭 在 口袋 里 的 量子 计算 机 ， 但 将 来 有 可 能 出 现 。 密 码 学 家 可 以 通过 
设计 基于 其 他 困难 问题 的 通信 协议 来 设法 绕 过 量子 攻击 ， 而 这 些 问题 必 
须 缺 乏 量子 计算 机 能 利用 的 良好 代数 结构 。 量 子 学术 界 则 为 我 们 提供 了 
另 一 个 解决 方案 ， 即 基于 量子 力学 的 密码 学 。 


我 们 对 于 复制 计算 机 数据 这 件 事 已 经 习以为常 了 。 差 不 多 每 一 个 计算 平 
台 都 会 提供 复制 和 粘贴 功能 。 我 们 可 以 把 文件 的 多 个 副本 放 在 不 同 目录 
下 或 不 同 的 机 右上 。 我 们 能 把 数据 备份 到 人 硬盘 或 是 “云端 "。 这 带 来 的 麻 
烦 是 ， 信 息 的 副本 太 多 了 ， 以 至 于 很 难 彻底 删除 茶 些 个 人 文件 或 电子 邮 
件 ， 并 确保 其 他 的 地 方 不 留 下 相应 的 副本 。 


与 之 相反 ， 量 子 比 特 不 能 被 复制 。 复 制 一 个 量子 比特 束 需 要 观察 它 ， 而 
无 论 以 何 种 受 限 的 方式 来 观察 ， 者 将 导致 量子 比特 转变 成 普通 的 比特 。 
乔治 想 把 一 个 量子 比特 递送 给 哈 利 。 如 果 埃 里 殉 在 途中 试图 复制 或 读 
取 ， 那 个 比特 将 变 成 一 个 普通 的 比特 。 当 然 这 本 号 并 不 构成 一 个 及 送 秘 
蜜 消息 的 方式 ， 毕 葛 消 妃 接 收 者 哈 利 也 必须 要 读 取 这 个 比特 ， 并 导致 它 
的 性 质 改 变 。 


1979 年 ， 来 自 蒙 特 利 尔 大 学 的 吉尔 斯 ' 布 拉萨 德 在 波多 歼 各 参加 了 IEEE 
计算 机 科学 基础 会 议 (Foundations of Computer Science conference ) ， 

该 会 议 是 理论 计算 机 科学 界 的 主要 会 议 之 一 。IBM 的 碍 理 : 贝 内 特 找到 
了 在 海滩 游泳 的 吉尔 斯 ， 这 次 海边 相 会 开启 了 两 位 科学 家 一 段 令 人 惊叹 
的 科研 合作 ， 其 工作 成 果 包 括 使 用 量子 比特 来 创造 理论 上 不 可 破译 的 密 
码 的 方法 。 贝 内 特 和 布 拉 陕 德 发 明 的 方法 通过 混合 使 用 经 典 和 量子 加 密 
技术 ， 既 能 让 乔治 和 哈 利 成 功 地 传输 一 把 密 钥 以 供 将 来 加 密 消 息 ， 又 能 
侦 测 到 该 密 钥 是 否 已 被 监听 者 截获 ， 那 样 的 话 他 们 可 以 再 试 一 次 。 


这 个 通信 协议 也 有 局 限 性 。 为 处 理 可 能 出 现 的 小 错误 ， 不 仅 要 增加 所 需 
的 量子 比特 的 个 数 ， 也 让 监听 者 埃 丝 特有 机 可 乘 ， 有 可 能 不 被 察觉 地 做 
些 手脚 。 人 们 又 研发 了 一 系列 更 复杂 的 通信 协议 来 应 对 这 些 新 问题 。 






































和 量子 计算 不 一 样 ， 贝 内 特 - 布 拉 蔷 德 协议 不 需要 量子 达到 彼此 纠缠 的 
状态 ， 而 且 已 经 实现 了 可 以 实际 运转 的 中 等 规模 的 量子 加 密 系 统 。 洛 斯 
阿拉 英 斯 国家 实验 室 的 研究 者 已 成 功 地 通过 148 千 米 长 的 光线 发 送 消 
恩 。 还 有 人 通过 大 气 在 加 那 利 群岛 的 两 个 岛屿 闻 发 送 了 信息 ， 距 离 也 将 
近 145 干 米 。 在 不 远 的 将 来 ， 我 们 将 能 用 卫星 来 发 送 使 用 量子 技术 的 不 
可 破译 的 密码 。 


那 我 们 为 什么 不 为 所 有 的 秘密 通信 需求 应 用 量子 密码 学 呢 ? 量 子 密码 技 
术 仍 处 于 实验 期 ， 十 分 昂贵 、 带 党 有 限 而 且 容 易 出 错 。 密 码 系 统 的 漏洞 
通常 不 在 于 使 用 的 加 蜜 方案 能 够 被 破解 ， 而 在 于 实际 的 执行 操作 中 的 薄 
弱 坏 节 。 如 果 量子 通信 协议 投入 实际 应 用 ， 其 操作 安全 性 很 可 能 和 经 典 
方法 一 样 差 ， 甚 至 有 可 能 更 差 。 为 外 ， 目 前 没有 已 知 的 方法 能 让 量子 密 
码 通过 互联 网 传输 ， 因 为 信息 通过 互联 网 从 源头 传输 到 目的 地 的 过 程 中 
要 经 过 多 次 路 由 的 转发 。 最 重要 的 是 ， 我 们 很 可 能 无 法 在 未 来 较 短 时 期 
内 看 到 能 解决 因数 分 解 问题 的 计算 机 ， 无 论 是 量子 计算 机 或 是 其 他 的 计 
算 机 。 目 前 所 用 的 密码 在 很 长 一 段 时 期 内 都 将 是 安全 的 。 






































9.3 量子 隐形 传输 


1996 年 2 月 的 《科学 美国 人 》 杂 志 在 封 二 刊登 了 IBM 的 广告 ， 宣 传 该 公 
司 的 研究 新 进展 。 


很 多 年 来 她 和 住 在 大 阪 的 朋友 分 享 食谱 。 她 问 他 展示 了 几 百 种 使 用 红 
辣椒 的 方式 。 他 则 分 享 了 寿 暑 烧 的 独家 秘方 。 有 一 天 ， 玛 格 丽 特 女 十 
给 小 泽 先 生发 了 一 封 电邮 ， 里 面 说 : “做 好 准备 ， 我 给 你 心灵 传输 
(teleport) 了 一 份 炖 牛肉 。” 玛 格 丽 特 女士 对 技术 的 要 求 稍微 有 点 超 
前 ， 但 我 们 一 直 在 为 实现 她 的 愿望 而 努力 。 来 和 目 IBM 的 科学 家 和 他 的 
同事 们 友 现 了 一 种 方法 ， 能 将 一 个 物体 原 地 分 解 、 再 在 力 一 个 地 点 暑 
发 无 伤 地 重 现 它 。 听 起 来 像 变 魔术 ， 但 是 他 们 取得 的 突破 性 进展 将 影 
啊 到 科技 生活 的 方方面面 ， 从 研发 未 来 的 计算 机 ， 到 拓展 人 类 对 宇宙 
的 认 知 。 真 是 一 群 聪明 的 家 伙 ! 但 他 们 中 还 没有 一 个 人 能 把 肉 馅 塞 进 
卷 心 染 里 。 





图 9-3 IBM 的 广告 。 由 IBM 公 司 提供 


广告 中 标榜 的 技术 是 怎么 回 事 ?” 与 其 说 它 和 炖 牛肉 有 关系 ， 不 如 说 和 量 
子 比特 有 关系 。 而 量子 比特 真 的 可 以 原 地 分 解 ， 再 在 男 一 个 地 点 重 现 ， 
就 好 像 变 魔术 一 样 。 广 告 中 提 到 的 研究 人 员 就 是 1993 年 在 IBM 工 作 的 科 
学 家 碍 理 : 贝 内 特 和 他 的 同事 们 ， 其 中 包括 吝 尔 斯 : 布 拉 蔷 德 。 为 我 们 带 
来 量子 加 密 技 术 的 这 群 人 ， 也 发 明了 量子 隐形 传输 。 





假如 阿 瑟 想 把 一 个 量子 比特 传输 给 哈 瑞 特 ， 该 如 何 做 呢 ? 


假 


图 9-4 ”量子 比特 


阿 蕊 可 以 选择 用 联邦 快递 来 寄 送 这 个 量子 比特 ， 但 是 如 果 海 天 人 员 想 但 
看 包 衷 内 容 ， 就 会 毁 掉 这 个 量子 比特 ， 让 它 变 成 只 能 取 真 假 二 值 之 一 的 
普通 比特 。 即 使 阿 合 十 分 小 心地 亲自 运送 这 个 量子 比特 ， 他 也 不 可 能 完 
全 如 免 它 在 与 外 界 环境 的 相互 作用 中 被 损坏 。 


阿 蕊 也 可 以 发 送 这 个 量子 比特 的 摘 述 信息 (-0.55 真 , 0.84 假 )， 哈 瑞 特 根据 
描述 重建 一 个 完全 相同 的 量子 比特 。 但 如 果 阿 琶 只 有 量子 比特 本 身 ， 他 
无 法 对 其 准确 的 摘 述 做 出 判断 ， 因 为 任何 试图 测度 量子 比特 的 行为 都 将 
导致 它 夫 缩 为 真 或 假 二 值 之 一 。 


贝 内 符 和 同事 们 为 阿 全 向 哈 瑞 特 传输 量子 比特 提供 了 一 种 方法 ， 但 有 一 
个 缺点 。 阿 瑟 和 哈 瑞 特 需要 事先 准备 一 些 役 此 纠缠 的 量子 比特 。 


图 中 带 心 形 的 量子 比特 处 于 纠缠 状态 ， 分 别 为 阿 基 和 哈 瑞 特 持 有 。 如 宁 
阿 琴 观测 他 的 量子 比特 ， 他 会 等 概率 地 看 到 “ 真 ” 或 “ 假 "。 但 大 阿 倒 看 到 








的 是 “* 真 ”， 那 哈 瑞 特 看 到 的 必然 是 “ 真 ”， 如 果 他 看 到 了 “ 假 >， 那 她 看 到 
的 也 是 “ 假 >， 这 和 本 章 前 面 介绍 的 棒球 比赛 是 类 似 的 。 


候 


阿 嫩 哈 瑞 特 


图 9-5 纠缠 


阿 世 现在 有 两 个 量子 比特 ， 标 有 五 角 星 的 用 来 传输 ， 标 有 心 形 的 和 哈 瑞 
特 的 量子 比特 处 于 纠缠 态 。 之 前 提 到 过 ， 这 两 个 量子 的 组 合 态 在 四 维 空 
间 表 现 为 一 个 球体 。 阿 瑟 在 不 观察 量子 比特 的 情况 下 小 心地 旋转 这 个 四 
维 球 。 然 后 阿 登 观测 这 两 个 量子 比特 ， 得 到 两 个 普通 的 比特 〈0 或 1) 。 


阿 琶 把 这 两 个 普通 的 比特 传送 给 哈 瑞 特 。 其 中 一 个 比特 告诉 哈 瑞 特 是 否 
要 旋转 她 的 量子 比特 ， 必 一 个 则 表示 是 人 否 要 翻转 它 。 哈 瑞 特 根据 指令 进 
行 相应 的 操作 。 接 着 轻 吹 一 口气 ， 大 喊 一 声 “ 变 ! ”袖子 里 什么 部 没 藏 ! 
突然 ， 哈 瑞 特 就 得 到 了 阿 瑟 原来 的 那个 量子 比特 。 令 人 晨 恢 的 是 ， 这 一 
切 都 是 真 的 。 


阿 琶 的 两 个 量子 比特 发 生 了 什么 ”它们 在 被 观测 到 的 那 一 刻 就 咒 灭 了 。 
否则 ， 阿 琶 将 制造 出 量子 比特 的 副本 ， 这 是 量子 力学 法 则 所 禁止 的 。 





























当 阿 登 操 作 和 测量 他 的 量子 比特 时 ， 哈 瑞 特 的 比特 未 受 影响 。 阿 瑟 不 能 
通过 对 目 己 的 量子 比特 的 操作 而 影响 到 哈 瑞 特 的 量子 比特 ， 人 否则 阿 瑟 就 
有 了 和 哈 瑞 特 通信 的 方法 ， 这 种 信息 传递 的 速度 比 光 速 还 快 ， 这 在 物理 
学 上 是 不 可 能 的 。 


当 哈 瑞 特 接收 到 阿 蕊 传 来 的 两 个 比特 时 ， 这 个 信息 能 让 她 把 自己 的 量子 
比特 看 做 阿 琶 原来 的 量子 比特 经 过 量子 操作 后 的 版 本 。 这 两 个 普通 比特 
准确 地 告诉 了 哈 瑞 特 要 如 何 逆转 这 些 操作 ， 才 能 恢复 阿 琶 原来 的 那个 量 
子 比特 。 哈 瑞 特 无 法 检测 阿 琶 的 操作 ， 但 随 看 阿 琴 传送 过 来 的 两 个 普通 
比特 ， 一 个 完好 无 损 的 量子 比特 残 像 变 魔 术 似 的 被 传输 过 来 了 。 


假 








并 


图 9-6 


怎么 把 这 一 切 和 炖 牛肉 或 者 《星际 迷航 》 中 那些 历 害 的 传送 右 联 系 在 一 
起 ? 假如 我 想 用 量子 隐形 传输 从 芝加哥 到 东京 。 某 个 公司 会 为 我 准备 一 
大 堆 处 于 纠缠 态 的 量子 ， 把 其 中 的 一 半 小 心地 运送 到 乞 加 可 ,为 一半 运 
送 到 东 系 。 然 后 我 在 芝加哥 的 一 个 小 房间 里 和 数量 多 到 足够 描述 我 的 量 
子 比 特 待 在 一 起 ， 在 茶 个 高 维 空间 被 旋转 ， 然 后 经 过 测量 变 成 经 典 的 比 
特 。 这 些 比 特 被 传送 到 该 公司 的 东 和 泵 分 广 机 构 ， 然 后 那里 的 人 们 在 一 个 
小 房间 里 以 恰当 的 方式 旋转 另 一 些 量子 比特 ， 打 开房 门 ， 我 就 出 现 了 。 


酷 ! 

















那 堆 役 此 纠缠 的 量子 就 这 样 被 消耗 了 。 要 传送 别人 或 者 把 我 传 回去 就 需 
要 一 扒 新 的 处 于 纠缠 态 的 量子 比特 。 其 实 道理 和 航空 燃油 差不多 。 我 从 
东 束 坐 飞机 回 家 ， 不 可 能 重新 使 用 那些 在 来 东京 的 航班 上 消耗 的 燃油 。 


更 令 人 担心 的 问题 是 如 何 让 那些 摘 述 我 的 海量 量子 (规模 可 能 达到 3 个 
10 亿 相 乘 的 数量 级 ， 基 本 上 相当 于 构成 人 体 的 原子 数量 ) 保持 在 完全 的 
纠缠 状态 ， 这 可 能 还 严重 低估 了 所 需 的 量子 比特 数量 。 即 使 有 极 小 部 分 
的 量子 和 外 界 环境 发 生 轻微 作用 而 丧失 了 纠缠 态 ， 从 另 一 头 出 现 的 我 惑 
很 可 能 被 毁 形 ， 甚 至 变 成 一 团 死 肉 。 所 以 你 先 走 ， 我 宁愿 慢 一 点 ， 消 耗 
一 些 航空 燃油 》 虽 们 区 京 见 o 




















9.4 量子 的 未 来 


有 些 研 究 者 认为 应 该 从 量子 角度 重新 审视 所 有 的 计算 问题 。 即 使 量子 计 
算 机 不 能 解决 NP 完 全 问题 ， 它 对 量子 世界 的 仿真 也 将 极 大 促进 人 类 对 
物质 、 宇 宙 乃 至 人 类 大 脑 的 认 知 ， 从 而 推动 科技 的 进步 ， 取 得 今天 所 无 
法 想象 的 成 就 。 


还 有 人 看 到 ， 量 子 研 究 从 20 世 纪 90 年 代 中 期 开始 在 算法 和 硬件 两 个 方面 
的 进展 都 十 分 缓慢 ， 据 此 怀疑 能 否 看 到 量子 在 计算 设备 中 起 到 关键 性 作 
用 的 那 一 天 。 如 果 缺 乏 单 命 性 的 进展 ， 量 子 计算 技术 在 未 来 一 段 时 期 内 
仍 将 停留 在 科 约 作品 中 。 


如 果 量 子 不 是 计算 领域 的 下 一 个 浪潮 ， 那 什么 古 呢 ? 有 哪些 巨大 的 计算 
挑 碾 在 前 方 等 待 着 我 们 ? 且 符 下 草 分 解 。 








第 10 章 ”未 来 


我 本 人 对 P/NP 问 题 得 到 解决 的 前 景 持 悲观 态度 : 我 认为 PzNP， 而 且 此 
生 都 看 不 到 它 的 证 明 。 我 们 不 会 见证 第 2 章 中 美妙 世界 的 到 来 ， 但 是 也 
不 能 排除 其 可 能 性 。 我 认为 INP 问 题 在 未 来 的 几 个 世纪 内 仍 将 是 一 个 未 
解 之 谜 。 


PNP 问 题 不 仅仅 是 一 个 数学 上 的 异类 。 虽 然 我 们 不 能 直接 解决 它 ， 但 研 
完 它 的 过 程 赋予 了 我 们 一 种 通用 的 框架 ， 有 助 于 思考 如 何 应 对 从 实际 二 
求 中 产生 的 那些 困难 的 问题 。 今 天 人 们 在 计算 学 方面 面临 哪些 重大 挑 
战 ? 


。 并 行 计算 : 曾经 每 过 18 到 24 个 月 ， 计 算 机 的 计算 速度 就 提高 一 僧 ， 
但 现在 我 们 正在 触及 物理 极限 ， 将 来 很 难 制造 出 比 现在 快 得 多 的 处 
理 句 。 劝 一 方面 ， 计 算 机 正在 模 癌 扩张 ， 可 以 让 多 个 处 理 融 一 起 工 
作 ， 不 论 是 在 同一 块 作 片上 ， 还 是 在 云端 。 如 何 调整 我 们 的 算法 ， 
以 适应 这 个 日 趋 并 行 化 的 世界 呢 ? 


大 数据 : 从 互联 网 到 科学 实验 再 到 仿真 研究 ， 我 们 每 天 都 在 生成 海 
量 的 数据 。 如 何 试图 理解 、 感 受 、 学 习 如 此 庞杂 的 信息 ， 并 形成 预 
测 能 力 ? 


一 切 事 物 的 网 络 化 : 世界 上 大 部 分 地 区 都 有 计算 机 网 络 ， 无 论 人 们 
使 用 的 是 像 Facebook 这 样 的 社交 了 网络， 或 者 仅仅 通过 电子 邮件 交 
流 。 很 快 几 乎 所 有 人 造 的 物品 都 将 成 为 这 张大 网 的 一 部 分 ， 从 我 们 
穿 的 衣服 ， 到 阅读 时 提供 照明 的 灯泡 。 我 们 如 何 更 好 地 利用 这 个 起 
级 互 连 的 世界 ? 


无 论 最 终 的 答案 是 P=NP 还 是 PzZNP， 对 这 一 问题 的 研究 过 程 本 身 都 将 在 
很 大 程度 上 影响 我 们 应 对 这 些 挑 成 的 方式 。 











10.1 并 行 计算 


1965 年 ， 戈 登 : 摩 尔 注 意 到 一 种 称 为 晶体 省 的 基本 元 件 在 单 块 计算 机 心 
片上 的 数量 每 年 都 在 总 剧 增加 。 摩 尔 大 胆 预言 ， 单 块 必 片 上 的 晶体 管 数 
量 大 概 每 两 年 就 会 翻 一 倍 ， 这 一 趋势 将 持续 至 少 10 年 的 时 间 。 现 在 人 们 
称 其 为 “摩尔 定律 >， 这 个 定律 从 1975 年 直到 今天 都 有 效 ， 甚 至 在 今后 的 
很 多 年 内 都 将 有 效 。 


在 很 长 一 段 时 间 里 ， 摩 尔 定律 意味 着 计算 速度 的 飞快 提升 。2005 年 前 
后 ， 计 算 机 开始 触及 物理 极限 ， 即 让 处 理 器 跑 得 更 快 一 点 所 消耗 的 能 量 
超过 了 提升 的 速度 能 够 带 来 的 好 处 。 人 们 反而 要 稍微 降低 处 理 器 的 速 
度 ， 以 改进 能 源 的 消耗 。 


然而 我 们 还 是 往 必 片 里 塞 更 多 的 晶体 管 。 要 这 么 多 晶体 管 做 什么 用 呢 ? 
现在 这 些 心 片 在 同一 时 间 可 以 做 几 件 事情 ， 以 并 行 的 方式 工作 ， 从 而 比 
同一 时 间 只 做 一 件 事 的 方式 更 快 地 解决 问题 。 


让 我 们 来 看 一 台 特 殊 的 机 器 : IBM 公 司 的 华 生 (Watson) 。2011 年 2 
月 ， 它 在 函 猿 闻 目 Jeopardy 的 第 一 集中 得 了 冠军 。 华 生 由 90 台 IBM 
POWER 750 服 务 器 组 成 ， 每 台 都 有 4 个 POWER7 处 理 器 。 一 个 POWER7 
处 理 器 的 内 部 其 实 有 8 个 处 理 器 〈 也 叫 核心 ) ， 所 以 它 能 同时 做 8 套 运 
算 。 这 样 ， 每 台 服 务 器 就 有 32 个 核心 ， 而 华 生 系 统一 共有 2880 个 核心 。 
华 生 能 同时 做 2880 套 计算 ， 所 以 它 能 理解 Jeopardy 中 给 出 的 “答案 ”， 并 
判断 每 一 环节 中 是 否 该 抢先 对 手 按 下 抢答 器 。 根 据 摩尔 定律 ， 在 不 远 的 
将 来 ，2880 个 并 行 处 理 核心 显得 微不足道 ， 几 十 年 后 我 们 可 能 有 百 万 核 
或 几 十 亿 核 的 计算 机 。 


并 行 技术 的 发 展 对 很 多 计算 机 科学 领域 提出 了 新 的 技术 要 求 。 一 人 台 计 算 
机 如 何 诀 定 怎样 把 计算 量 在 数 个 核心 或 是 数 台 电脑 上 分 布 开 来 ， 以 达到 
最 佳 的 效能 ? 我 们 需要 考虑 多 核 计 算 机 因素 并 重 写 我 们 的 通用 编程 语言 
吗 ? 如 果 需 要 ， 该 如 何 做 呢 ? 


P/NP 问 题 同样 受到 并 行 搁 术 的 影响 。 记 得 本 书 开 篇 提 a 到 的 《但 理 和 巧 殉 
力 工厂 》 中 的 小 女孩 维 鲁 卡 : 索 尔 特 吗 ? 她 想 要 找到 藏 在 巧克力 包装 纸 
里 的 金 券 。 她 爸爸 就 采用 了 并 行 技 术 ， 把 大 量 的 巧 苑 力 分 配给 几 百 个 刊 


























花生 壳 的 工人 ， 让 她 们 同时 来 找 金 券 。 人 们 也 可 以 这 样 来 求解 NP 问 
题 ， 把 所 有 可 能 是 团 的 集合 分 配给 几 台 计算 机 以 及 每 台 计 算 机 的 几 个 核 
心 。 这 可 能 会 让 一 个 持续 数 周 的 计算 在 几 小 时 内 结束 ， 但 对 于 某 些 NP 
问题 的 求解 还 是 没什么 帮助 。 如 果 我 们 动用 100 万 台 计 算 机 ， 每 台 有 10 
亿 个 核心 ， 每 个 核心 每 秒 能 进行 1x101 个 操作 ， 仍 然 需要 花费 几乎 10100 
倍 于 宇宙 寿命 的 时 间 。ZP/NP 问 题 在 并 行 的 世界 里 仍然 是 有 效 的 。 


而 那些 P 类 的 问题 ， 即 我 们 能 高 效 地 解决 的 问题 义 怎 么 样 呢 ?我 们 能 最 

大 限度 地 利用 多 计算 机 和 多 处 理 圳 的 优势 吗 ? 大 多 数 情况 下 我 们 可 以 通 
过 修改 算法 来 实现 这 一 点 。 从 基本 的 算术 到 找 最 短路 径 再 到 匹配 问题 ， 

所 有 这 些 问题 都 有 能 扩展 到 多 核 来 并 行 计算 的 算法 。 


像 P 和 NP 一 样 ， 对 于 那些 能 用 并 行 算法 快速 解决 的 问题 集合 我 们 也 起 了 
一 个 名 字 ， 叫 做 NC， 代 表 Nick's Class， 它 得 名 于 并 行 算法 的 先驱 尼 古 
拉 斯 : 皮 绢 格 。 如 果 P=NC， 那 任何 一 个 我 们 能 高 效 解 决 的 问题 ， 都 能 通 
过 并 行 计 算 更 快 地 解决 。 我 们 不 知道 是 否 有 P=NC， 更 不 知道 是 否 
NP=NC。NP=NC 意 味 着 每 一 个 NP 搜索 问题 都 能 用 极 快 的 速度 在 并 行 计 
算 的 计算 机 和 《或 ) 核心 上 找到 有 效 的 解 ， 这 预示 着 一 个 比 P=NP 更 加 
美妙 的 世界 。NP=NC 的 可 能 性 很 小 ， 但 它 和 P=NP 一 样 ， 也 是 一 个 巨大 
的 未 解 之 谜 。 

















10.2 ”处 理 大 数据 


在 1 秒 钟 的 时 间 里 ， 人 们 生成 了 35 分 钟 的 YouTube 视 频 、1600 条 Twitter 
上 的 消息 、11 000 条 Facebook 消 息 、50 000 次 Google 搜 索 请 求 ， 以 及 300 
万 封 电 子 邮 件 《〈 不 过 其 中 90% 都 是 垃圾 邮件 ) 。 


哈 动 望远镜 从 它 的 轨道 扫 摘 太空 ， 每 秒 传 回 20 万 字 市 的 消息 。1 字 节 数 
据 大 概 就 是 1 个 字母 。 哈 动 望远镜 的 继任 者 詹姆斯 :韦伯 太空 望远镜 拥有 
更 大 的 抛物 线形 的 镜片 ， 每 秒 将 回 地 球 传 回 350 万 子 节 的 数据 。 


坐落 在 法 国 和 瑞士 边境 线 上 的 大 型 强 子 对 接 机 (LHC) 是 世界 上 最 大 的 
粒子 加 速 器 。 它 平均 每 秒 生成 5 亿 字 节 的 数据 ， 每 一 年 的 每 一 秒 都 是 如 
此 ， 而 一 年 有 3100 万 秒 。 


CERN 即 欧洲 核子 研究 组 织 ， 它 是 大 型 强 子 对 播 机 的 建造 者 和 维护 机 
构 。 那 里 的 科学 家 们 还 建造 了 一 个 LHC 计算 网 格 ， 将 产生 的 大 量 数 据 分 
发 到 位 于 34 个 国家 的 服务 右上， 让 全 世界 的 科学 家 都 能 访问 并 分 析 LHC 
的 数据 。 


人 类 DNA 序 列 包 含 大 概 5500 万 字 节 的 信息 。 全 世界 70 亿 人 的 基因 序列 大 
概 包含 4x10 比特 的 信息 。 这 还 只 是 人 类 一 个 物种 。 


我 们 很 容易 就 能 制造 各 种 廉价 的 传感器 ， 测 量 从 温度 到 动作 、 从 声音 到 
辐射 的 各 种 事物 。 每 一 个 传感器 都 在 持续 生成 信息 ， 而 实际 中 通常 会 使 
用 上 千 个 传感器 。 有 人 形容 美国 军队 “在 传感器 里 游泳 ， 在 数据 里 淹 
死 "。 


不 是 所 有 数据 都 来 自 外 部 世界 。 许 多 科学 实验 实际 操作 起 来 十 分 困难 或 
者 成 本 昂 贯 ， 于 是 人 们 借助 计算 机 来 进行 仿真 实验 ， 也 可 以 了 解 生物 
学 、 物 理学 和 化 学 系统 中 的 各 种 交互 作用 。 这 些 仿真 实验 同样 生成 了 大 
量 的 有 符 分 析 的 数据 。 


上 述 各 种 来 源 的 数据 虽然 数量 很 大 ， 但 其 中 大 部 分 都 是 无 用 信息 ， 有 的 
是 随机 噪声 ， 还 有 的 是 见 余数 据 。 找 到 数据 集中 关键 而 有 用 的 部 分 古 很 
困难 的 ， 并 且 需 要 对 信息 的 深度 解读 。 如 果 P=NP， 我 们 只 要 用 算法 把 



































数据 过 一 过 ， 惑 能 挑 出 其 中 重要 的 部 分 ， 再 使 用 基于 奥 卡 姆 剃刀 法 则 的 
工具 ， 残 能 形成 对 数据 的 理解 和 预测 能 


而 我 们 不 太 可 能 生活 在 那样 一 个 美妙 的 世界 ， 我 们 只 能 尽量 根据 实际 需 
求 寻 找 和 修改 我 们 的 算法 。 从 大 量 的 数据 中 理 出 头绪 是 一 个 非常 困难 、 
但 也 十 分 重要 的 计算 问题 。 


大 数据 往往 是 好 事 ， 尤 其 是 在 机 器 学 习 领 域 。 机 器 学 习 研 究 的 是 如 何在 
给 定 的 数据 集 上 训练 算法 。 拥 有 的 数据 越 多 ， 训 练 出 的 算法 就 越 好 。 通 
常 ， 拥 有 更 多 数据 胜 过 拥有 更 好 的 算法 。Google 在 垃圾 邮件 检测 、 语 首 
识别 和 语言 翻译 等 方面 能 有 不 错 的 表现 ， 靠 的 就 是 它 所 能 使 用 的 大 量 样 
例 数据 。 


在 不 远 的 将 来 ， 我 们 拥有 的 数据 将 帮助 我 们 更 好 地 分 析 个 人 健康 状况 ， 
建造 更 智能 和 市 能 的 电力 网 络 ， 也 将 让 目 动 驾驶 的 汽车 得 到 普及 ， 并 让 
我 们 对 所 处 的 宇宙 的 基本 性 质 有 更 深 的 了 解 。 如 何 理解 数据 以 更 好 地 丰 
富 人 们 的 生活 ， 是 计算 机 科学 家 面临 的 一 大 挑战 。 

















10.3 ”一 切 事物 的 网 络 化 


全 世界 大 概 有 20 亿 人 通过 互联 网 彼此 联系 ， 如 电子 邮件 或 社区 网 络 。 如 
今 互 联网 融 给 我 们 的 交流 、 合 作 、 学 习 和 休闲 方式 ， 是 在 20 世 纪 不 可 想 
象 的 。 


如 果 我 们 把 各 种 物品 也 放 到 互联 网 上 会 发 生 什么 ? 在 不 久 的 将 来 ， 我 们 
将 拥有 各 种 能 上 网 的 小 型 廉价 必 片 ， 无 论 是 通过 Wi-Fi、 移 动 蜂 贸 网 
络 ， 还 是 通过 其 他 正在 研发 的 无 线 通 信 系 统 。 我 们 能 把 这 些 必 片 放 到 几 
乎 任何 东西 里 ， 从 我 们 罕 的 衣服 到 我 们 开 的 车 ， 再 到 我 们 买 的 食品 的 包 
装 。 你 不 用 纸 笔 做 记录 就 能 追踪 一 切 ， 从 孩子 们 是 人 否 系 好 安全 带 到 你 每 
天 卡路里 的 摄 入 量 。 没 有 牛奶 或 洗 发 液 了 ? 别 担心 ， 补 给 品 已 经 自动 友 
货 ， 正 在 到 你 家 的 路 上 。 你 再 也 不 会 误 服 药品 了 。 你 穿 的 衣服 会 告诉 你 
它们 是 否 适 合 特 定 的 场合 和 天 气 ， 或 者 会 说 :“ 你 真 的 想 穿 这 件 衬衫 来 
搭配 这 条 裤子 吗 ? ”这 对 于 那些 色盲 人 士 或 者 不 懂 服 装 搭 配 的 人 一 定 大 
有 神 苑 。 


你 再 也 不 会 丢 钥 古 、 钱 包 、 门 票 ， 或 者 任何 其 他 的 东西 了 。 你 甚至 都 不 
用 携带 这 些 东 西 。 手 机 发 一 个 信号 束 能 让 你 家 门 锁 在 你 接近 时 打开 。 目 
动 取 球 机 直接 会 把 钱 交 到 你 手 上 。 你 可 以 从 商店 里 拿 起 东西 就 走 。 所 有 
的 付 球 和 扣 费 部 是 目 动 故 生 的 。 


上 述 场 景 的 实现 需要 所 有 的 设备 部 能 彼此 协作 ， 并 拥有 展 好 的 配合 意 

识 。 需 要 研发 出 一 种 合理 的 方式 ， 让 这 些 设备 能 够 交换 信息 ， 同 时 保护 
个 人 的 隐私 。 我 们 将 在 前 所 未 有 的 程度 上 实现 协同 。 想 象 如 果 所 有 的 汽 
车 能 够 彼此 合作 ， 交 通 该 有 多 顺畅 。 而 这 些 进步 的 实现 ， 都 要 求 算法 能 
对 茶 些 大 规模 问题 进行 快速 、 稳 定 和 持续 的 求解 。 除 非 交 通 系统 能 够 快 
速 啊 应 ， 否 则 一 次 很 小 的 交通 事故 也 可 能 造成 大 面积 的 交通 次 痪 。 这 些 
问题 中 一 部 分 涉及 了 P/NP 问 题 ， 而 我 们 只 能 尽 最 大 努力 去 处 理 好 它们 。 


Sun 公 司 〈 现 在 是 甲骨 文公 司 的 一 部 分 ) 在 20 世 纪 90 年 代 有 一 句 口 

号 : “网络 即 计 算 机 。” 网 络 上 彼此 独立 工作 的 机 器 通过 协作 ， 在 整体 上 
可 被 看 做 一 个 计算 设备 。 当 一 切 事物 都 能 被 网 络 化 ， 我 们 就 有 了 一 个 非 
营 大 的 计算 机 。 驯 服 这 头 狐 兽 虽然 不 易 ， 但 它 也 将 为 我 们 撞 开 一 书 充 满 
新 的 机 遇 的 大 门 。 












































10.4 应 对 科技 变革 


并 行 计算 、 大 数据 和 一 切 事物 的 网 络 化 并 不 只 是 出 现在 科幻 作品 中 的 概 
念 。 它 们 更 是 一 场 早 已 开始 的 变革 的 宣言 ， 而 这 场 变 单 将 在 未 来 的 一 二 
十 年 里 横扫 世界 。 社 会 将 会 发 生 怎样 的 变化 ? 


几乎 不 可 能 事先 预测 某 项 科技 创新 对 于 社会 的 巨大 影响 力 。 在 20 世 纪 50 
年 代 ， 经 营 着 一 家 卡车 公司 的 马尔 科 姆 :麦克 莱恩 发 明了 一 种 不 用 旨 货 
就 能 直接 从 轮 船 移动 到 卡车 上 的 集装箱 。 他 的 发 明 推 动 了 运输 业 的 一 场 
革命 ， 在 这 场 革 命中 诞生 了 可 容纳 上 于 个 集装箱 的 巨型 轮船 ， 也 孕育 了 
不 需要 任何 码头 工人 就 能 运转 的 自动 化 港口 。 这 个 历史 事件 在 当时 的 文 
化 产物 中 也 有 所 体现 ， 如 电影 《码头 风云 》 (On the Waterfront) 和 电 
视 剧 《一 家 子 》 (Allin the Family) 。 这 跟 中 国 的 崛起 也 有 一 定 的 关 

系 ， 借 助 一 个 个 钢 制 的 箱子 ， 中 国 将 出 产 的 货物 运送 到 了 世界 各 地 。 


汽车 推动 了 郊区 的 崛起 。 手 机 意味 独 我 们 再 也 不 用 提前 做 好 计划 。 
Twitter 帮助 人 民 推 翻 了 政府 的 统治 。 科 技 对 人 类 的 影响 体现 在 各 种 难以 
预料 的 方面 。 人 们 最 好 做 好 准备 ， 因 为 这 一 切 马 上 就 要 再 次 发 生 。 


除了 要 考虑 计算 的 问题 ， 我 们 还 需要 考虑 人 的 因素 。 人 们 总 会 利用 新 的 
科技 做 一 些 坏事 ， 有 的 人 是 无 意 的 ， 另 一 些 人 则 是 故意 为 之 。 我 们 还 需 
要 具备 符合 人 们 认 知 逻辑 的 良好 产品 设计 ， 让 人 们 能 轻松 地 上 手 使 用 新 
一 代 的 科技 设备 ， 尽 可 能 不 要 让 学 习 曲 线 太 陡 。 


可 能 会 有 人 和 洽 试 控制 科技 ， 其 动机 有 可 能 是 出 于 个 人 利益 ， 还 有 可 能 是 
为 了 获取 他 人 的 信息 。 最 坏 的 可 能 性 是 人 们 会 用 科技 制造 肪 虎 。 有 些 厅 
烦 无 伤 大 雅 ， 只 是 比较 烦人 而 已 ， 另 一 些 则 会 造成 大 量 的 财产 损失 ， 甚 
至 造成 人 员 伤亡 。 为 了 阻止 茶 些 人 利用 科技 手段 制造 社会 灾难 ， 人 们 有 
必要 加 强 密码 学 和 安保 措施 的 研究 和 使 用 ， 并 且 时 刻 保持 警惕 。 


需要 注意 的 是 ， 当 一 项 科技 在 大 部 分 情况 下 都 表现 民 好 时 ， 大 家 会 误 以 
为 它 能 在 所 有 情况 下 都 表现 民 好 ， 这 也 许 是 其 最 危险 的 一 面 。 如 条 人 们 
对 科技 投入 过 多 的 信任 ， 它 可 能 就 会 在 大 家 坚 无 防备 的 时 候 突然 挥 链 

子 。 未 曾 预 料 到 的 罕见 事件 的 发 生 会 加 剧 这 个 问题 的 严重 程度 。 一 些 例 
子 包括 : 卡特 里 娜 巾 风 黎 击 下 新 奥 尔 民 市 的 防洪 坤 决口 ，2010 年 深水 地 






































平 线 (Deepwater Horizon) 公司 的 钻井 平台 爆炸 之 后 大 量 原油 泄漏 的 事 
故 ， 以 及 2011 年 日 本 地 震 和 海啸 之 后 福 岛 核电 站 核 泄漏 灾难 。 我 们 应 该 
像 对 竺 未 被 驯服 的 狐 兽 那样 正视 科技 的 力量 与 危险 性 。 发 生 大 规模 科技 
事故 的 概率 虽然 很 小 ， 但 仍 有 可 能 性 。 人 们 要 警惕 不 要 让 科技 事故 酝酿 
出 更 加 巨大 的 灾难 。 


10.5 “关于 P/NP 问 题 的 结束 语 


证 明 PzNP 并 非 易 事 。 你 需要 证 明 不 存在 有 效 的 算法 能 解决 团 问 题 或 任 
何其 他 的 NP 完 全 问题 ， 这 些 算法 既 包括 现 有 的 也 包括 将 来 发 明 的 。 如 
何 证 明 每 一 个 潜在 的 算法 都 必 将 失败 ? 


人 们 相信 这 样 的 证 明 总 有 一 天 会 出 现 ， 但 有 可 能 需要 过 上 20 年 ，200 
年 ， 甚 至 2000 年 。 总 有 一 天 ， 当 人 们 发 展 出 的 新 技术 最 终 能 证 实 P<NP 
的 时 候 ， 数 学 家 们 会 兴高采烈 ， 为 一 个 伟大 的 问题 得 到 一 个 伟大 的 解答 
而 欢呼 。 而 求解 PINP 问 题 过 程 中 产生 的 技术 将 让 我 们 次 刻 认 识 高 效能 计 
算 的 威力 ， 这 种 东西 会 渗透 到 社会 生活 的 方方面面 。 


P/NP 问 题 远 远 不 只 是 一 个 数学 谜 题 那么 简单 。 它 是 一 种 思考 的 方法 ， 一 
种 根据 问题 的 内 在 难度 对 其 进行 分 类 和 认识 的 方法 。 虽 然 尚 没有 Pz<NP 
的 确 首 证 据 ， 我 们 起 码 知道 了 : 当面 临 一 个 NP 完 全 问题 时 ， 不 可 能 找 
到 一 个 在 所 有 情况 下 都 能 解决 该 问题 的 算法 。 这 时 就 需要 借助 于 其 他 的 
工具 ， 如 近似 计算 、 局 发 式 方法 、 骏 力 破 解 等 方法 的 组 合 ， 然 后 尽 我 们 
所 能 地 争取 最 好 的 结果 。NP 完 全 性 理论 给 了 我 们 一 个 通用 的 思考 杠 
架 ， 人 允许 我 们 建立 一 套 由 很 多 技术 组 成 的 工具 体系 ， 向 那些 难以 计算 的 
问题 发 起 有 效 的 攻击 。 


P/NP 问 题 让 学 术 界 团结 在 一 起 。 物 理学 、 生 物 学 、 经 济 学 以 及 其 他 许多 
领域 中 都 有 NP 完 全 问题 的 身影 。 虽 然 物 理学 家 和 经 济 学 家 所 关注 的 问 
题 有 很 大 的 差 寞 ， 但 这 两 类 问题 也 存在 着 共性 。 所 以 分 至 各 目的 工具 和 
技术 将 为 双方 都 带 来 巨大 的 好 处 。 例 如 ， 物 理学 中 为 了 寻找 物理 系统 的 
基态 而 开发 的 工具 ， 对 于 经 鹿 学 中 寻找 复杂 经 济 环境 中 可 能 出 现 的 均衡 
行为 也 是 有 帮助 的 。 


P/NP 问 题 内 在 的 难度 同样 促进 了 新 技术 的 发 展 。 当 代 密 人 码 学 家 从 P/NP 
问题 受到 启发 ， 把 密码 学 操作 过 程 从 一 门 艺术 变 成 了 科学 。 对 于 解决 
P/NP 问 题 的 强烈 需求 也 在 激励 人 们 建造 更 快 、 更 强 的 计算 系统 ， 众 生 了 
诸如 量子 计算 这 样 的 新 技术 。 


计算 是 一 种 和 过 程 有 关 的 活动 ， 而 过 程 不 仅仅 出 现在 计算 机 上 。PNP 问 
题 归根 到 后 与 自然 本 喘 的 极限 有 关 ， 与 生物 和 物理 系统 进化 的 极限 有 























天 ， 甚 至 可 以 说 与 人 类 思想 所 能 达到 的 极限 有 关 。 只 要 P/NP 问 题 还 是 一 
个 未 解 之 於 ， 人 类 就 无 法 确切 地 知道 自己 所 能 取得 的 成 就 的 极限 在 哪 
里 。 这 不 由 得 让 人 感到 精神 一 振 。 


章节 注释 和 文献 
本 书 的 内 容 基于 我 对 计算 复杂 度 领域 的 研究 经 验 ， 以 及 与 几 千 个 来 自学 


术 界 和 工业 界 同样 对 P/NP 问 题 感 兴趣 的 研究 者 。 书 中 的 一 些 内 容 改 编目 
我 的 博客 “Computational Complexity”(〈 计 算 复 杂 度 ) 。 


在 闭 书 过 程 中 ， 我 从 许多 资料 引用 了 一 些 故 事 、 例 子 和 结果 。 下 面 将 列 
出 所 有 的 资料 。 


所 有 对 于 这 些 资 料 或 链接 的 更 新 ， 以 及 文中 发 现 的 重大 错误 ， 都 将 公布 
在 本 书 的 网 站 http://press.princeton.edu/titles/9937.html 上 。 网 站 也 提供 了 
引用 的 图 书 、 访 谈 、 附 加 信息 以 及 P/NP 问 题 的 拓展 阅读 等 内 容 。 
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第 1 章 

维 露 卡 : 索 尔 特 的 故事 是 从 罗 和 尔 德 :达尔 的 小 说 Chariie and the Chocolate 
Factory (New York: Knopf, 1964) 中 摘录 的 。 

对 松 内容 子 工作 的 讨论 ， 即 她 的 科研 小 组 研发 的 解剖 学 上 正确 无 误 的 机 
械 手 ， 信 息 来 自 2010 CRA Snowbird Conference (2010 年 7 月 18 日 ) 上 的 
一 场 讲座 。 

旅行 推销 员 问 题 是 用 Mark Daskin 的 软件 生成 的 ， 网 址 


是 http://sitemaker.umich.edu/msdaskin/software。 





第 2 章 





除了 2.4 节 ， 本 章 其 余 内 容 都 是 我 虚构 的 ， 目 的 是 为 了 描绘 不 太 可 能 发 
生 的 P=NP 的 世界 。 
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弄 3 惠 

关于 米尔 格拉 姆 的 实验 ， 参 见 Stanley Milgram, “The Small World 
Problem,” Psychology Today 2, no. 1 (1967): 60-67。 

贝 肯 分 数 的 计算 来 自 Internet Movie Database。 


对 于 四 色 问 题 有 一 本 可 读 性 更 强 的 故事 ， 参 见 Robin Wilson, Four Colors 
Suffice: How the Map Problem Was Solved (Princeton, NJ: Princeton 
University Press, 2004)。 
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引用 库 克 的 话 其 实 有 修改 ， 经 过 了 一 些 现代 术语 的 蔡 换 。 原 文 如 下 


The theorems suggest that {tautologies} is a good candidate for an 
interesting set not in L*, and I feel it is worth spending considerable effort 
trying to prove this conjecture. Such a proof would be a major 
breakthrough in complexity theory. 


Steve Cook, “The Complexity of Theorem-Proving Procedures,” in 
Proceedings of the Third Annual ACM Symposium on Theory of Computing 
(New York: ACM), 151--158. 


卡 普 的 后 续 论 文 指 的 是 : Richard Karp, “Reducibility among 
Combinatorial Problems,” Complexity of Computer Computations 40, no. 4 


(1972): 85-103。 


Bob Sehlinger (author) and Len Testa (contributor), The Unofficial Guide 


Walt Disney World 2010 (New York: Wiley, 2010). 





4.3 节 内 容 取材 和 目 Donald Knuth, “A Terminological Proposal,”ACM 
SIGACT News 6, no. 1 (January 1974): 12-18。 


上 Kevin Sack, “60 Lives, 30 Kidneys, Al Linked,” New York Times, February 
19, 2012, Al. 
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本 章 从 以 下 资料 汲取 了 很 多 素材 。 


Lance Fortnow and Steve Homer, “A Short History of Computational 
Complexity,” Bulletin of the European Association for Theoretical Computer 
Science 80 (June 2003), “Computational Complexity” 专 栏 ， 以 及 与 许多 
研究 者 的 个 人 讨论 〈 包 括 斯 蒂 耸 ' 库 元 和 列 昂 尼 德 : 莱 文 ) 。 


Dennis Shasha and Cathy Lazere, “A Good Solution Is Hard to Find,” in Out 
of Their Minds: The Lives and Discoveries of 15 Great Computer Scientists 
(New York: Springer, 1995). 


Juris Hartmanis, “Observations about the Development of Theoretical 
Computer Science,” Annals of the History of Computing 3, no. 1 (January 
1981): 42--51. 


B. A. Trakhtenbrot, “A Survey of Russian Approaches to Perebor (Brute- 
Force Search) Algorithms,” Annals of the History of Computing 6, no. 4 
(October 1984): 384--400. 


Michael Sipser, “The History and Status of the P versus NP Question,” in 
Proceedings of the 24th Annual ACM Symposium on Theory of Computing 
(New York: ACM, 1992), 603-618. 这 篇 文章 中 包含 了 哥 德 尔 写 给 冯 : 诺 依 
曼 的 信件 副本 和 英文 译文 。 


柯 尔 英 哥 洛 夫 曾经 试图 成 为 历史 学 家 的 故事 得 到 了 几 个 俄罗斯 人 的 印 
证 ， 时 间 是 在 2003 年 4 月 27 日 至 5 月 2 日 ， 地 点 是 在 德国 的 Dagstuhl 召 开 的 











柯 尔 莫 哥 洛 夫 复 杂 度 及 应 用 百年 座谈 会 上 。 这 个 故事 也 记录 在 我 的 博 
客 “Compnutational Complexity” 上 ， 时 间 是 2003 年 5 月 1 日 。 


参考 文献 


Alan Cobham, “The Intrinsic Computational Difficulty of Functions,” in 
Proceedings of the 1964 International Congress for Logic, Methodology, and 
Philosophy of Science, 24—30. 


Stephen Cook, “The Complexity of Theorem-Proving Procedures,” in 
Proceedings of the Third Annual ACM Symposium on Theory of Computing 
(New York: ACM, 1971), 151—158. 


Jack Edmonds, “Paths, Trees and Flowers,” Canadian Journal of 
Mathematics 17 (1965): 449—467. 


Juris Hartmanis and Richard Stearns, “On the Computational Complexity of 
Algo- rithms,” Transactions of the American Mathematical Society 117 
(1965): 385-406. 


Richard Karp, “Reducibility among Combinatorial Problems,” Complexity of 
Computer Computations 40, no. 4 (1972): 85—103. 


Leonid Levin, “Universal Sequential Search Problems” [in Russian)], 
Problemy Pred. Informatsii 9, no. 3 (1971): 265—266. Translation in B. A. 
Trakhtenbrot, “A Survey of Russian Approaches to Prebor (Brute-Force 
Search) Algorithms,” Annals of the History of Computing 6, no. 4 (October 
1984): 384-400. 


Warren McCulloch and Walter Pitts, “A Logical Calculus of the Ideas 
Immanent in Nervous Activity,” Bulletin of Mathematical Biology 5, no. 4 
(1943): 115-133. 


Panel discussion, Complexity of Computer Computations 40, no. 4 (1972): 
169-185. 


Alan Turing, “On Computable Numbers, with an Application to the 


Entscheidungsproblem,” Proceedings of the London Mathematical Society 42 
(1936): 230-265. 


S. Yablonsky, “On the Impossibility of Eliminating PEREBOR in Solving 
Some Problems of Circuit Theory,” Doklady Akademii Nauk SSSR 124 
(1959): 44—47. 


Y. Zhuravlev, “On the Impossibility of Constructing Minimal Disjunctive 
Normal Forms for Boolean Functions by Algorithms of a Certain Class,” 
Doklady Akademii Nauk SSSR 132 (1960): 504—506. 
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旅行 推销 员 问 题 ! 的 例子 来 自 “CRPC Researchers Solve Traveling Salesman 
Problem for Record-Breaking 13,509 Cities”*”，2003 年 由 莱 斯 大 学 并 行 计算 
研究 中 心 举 行 的 一 次 新 闻 发 布 会 。 


1 旅行 推销 员 问 题 是 用 Mark Daskin 的 软件 生成 的 ， 网 址 是 http://sitemaker.umich. 
edumsdaskin/software。 


为 了 找到 地 图 填 色 的 启发 式 方法 的 例子 ， 我 回 网 络 社区 寻求 了 帮助 ， 在 
答疑 网 站 (http://cstheory.stackexchange.com/questions/4027/coloring- 
planar-graphs) 和 我 的 博客 上 发 布 了 帖子 。 


敌 友 国 各 省 地 图 取材 于 于 David P. Dailey, “Uniqueness of Colorability and 
Colorability of Planar 4-Regular Graphs Are NP-Complete”, Discrete 
Mathematics 30 (1980): 289—293。 
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第 一 句 中 引用 尤 里 斯 - 哈 特 马 尼 斯 的 话 来 自 于 他 1985 年 春季 在 康 奈 尔 大 
学 讲 的 一 堂 课 上 。 


关于 P/NP 策 略 ， 参 见 JACM 的 相关 页 面 
(http://jacm.acm.org/instructions/pnp) 。 


维 纳 里 : 德 奥 拉 利 卡 的 PINP 论 文 附 加 在 他 于 2010 年 8 月 6 日 发 送 的 一 封 电 
子 邮 件 中 ， 收 信人 是 我 和 其 他 21 个 研究 者 。 


吉 罗 拉 莫 的 故事 参见 David Kahn, The Codebreakers: The Story of Secret 
Writing (New York: Macmillan, 1967)。 
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本 章 关 于 密码 学 早期 历史 的 叙述 很 多 都 来 自 David Kahn 的 著述 ，The 
Codebreakers: The Story of Secret Writing (New York: Macmillan, 1967)。 


零 知 识 证 明 数 独 的 例子 源 于 我 在 2006 年 8 月 3 日 撰写 的 一 篇 博文 ， 发 布 在 
我 的 博客 “Computational 

Complexity” 上 : http://blog.computationalcomplexity.org/2006/08/zero- 
knowjledge-sudoku.html。 


参考 文献 


Whitfield Diffie and Martin Hellman, “New Directions in Cryptography,” 
IEEE Transactions on Information Theory 22, no. 6 (November 1976): 644— 
654. 


Craig Gentry, “Fully Homomorphic Encryption Using Ideal Lattices,” in 
Proceedings of the 41st Annual ACM Symposium on Theory of Computing 
(New York: ACM, 1979), 169-178. 


Ronald Rivest, Adi Shamir, and Leonard Adleman, “A Method for Obtaining 
Digital Signatures and Public-Key Cryptosystems,” Communications of the 
ACM 21, no. 2 (February 1978): 120-126. 

va ee 
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我 对 理 碍 德 : 忱 曼 在 量子 计算 学 中 起 到 的 作用 的 叙述 取材 目 David 
Deutsch 的 著作 ，“Quantum Computation,”Physics World, January 6， 


1992。 
参考 文献 


Charles Bennett and Gilles Brassard, “Quantum Cryptography: Public Key 
Distribution and Coin Tossing,” Proceedings of the IEEE International 
Conference on Computers, Systems, and Signal Processing (Amsterdam: 
Elsevier, 1984), 175—179. 


Charles Bennett, Gilles Brassard, Claude Crépeau, Richard Jozsa, Asher 
Peres, and William K. Wootters, “Teleporting an Unknown Quantum State 
via Dual Classical and Einstein-Podolsky-Rosen Channels,” Physical Review 
Letters 70 (1993): 1895-—1899. 


Lov Grover, “A Fast Quantum Mechanical Algorithm for Database Search,” 
in Proceedings of the Twenty-EFighth Annual ACM Symposium on Theory of 
Computing (New York: ACM, 1996), 212-219. 


Stephen Pincock, Codebreaker: The History of Codes and Ciphers (New 
York: Walker and Co., 2006), 151, for the Bennett and Brassard beach story. 


Peter Shor, “Polynomial-Time Algorithms for Prime Factorization and 
Discrete Loga- rithms on a Quantum Computer,” SIAM Journal on 
Computing 26 (1997): 1484--1509. 
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摩尔 定律 来 自 Gordon Moore, “Cramming More Components onto 
Integrated Circuits,” Electronics 38, no. 8 (April 19, 1965 )。 


华 生 的 硬件 配置 公布 在 IBM 的 “What Runs IBM Watson and Why” 博 文 
中 ， 作 者 是 David Davidian。 


集装箱 的 故事 来 自 Marc Levinson, The Box: How the Shipping Container 
Made the World Smaller and the World Economy Bigger (Princeton, NJ: 
Princeton University Press, 2008)。 


大 数据 的 统计 信息 的 来 源 
http:/www.youtube.com/t/press_statistics 


http://techcrunch.com/2011/03/14/new-twitter-stats-140m-tweets-sent-per- 
day-460k-accounts-created-per-day/ 


http://www.facebook.com/press/info.php?statistics 
http://email.about.com/od/emailtrivia/f/emails_per_day.htm 
http://public.web.cern.ch/publicv/en/lhc/Computing-en.html 
http://space.about.com/od/telescopesandoptics/p/hubbleinfo.htm 
http://webbtelescope.org/webb_telescope/technology_at_the_extremes/quick_ 


http://royal.pingdom.com/2011/01/12/internet-2010-in-numbers/ 
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05. 轻松 撰写 功能 规格 书 - 第 一 部 分 为 什么 要 
写 ? 
2000 年 10 月 2 日 ， 星 期 一 


齐 尔 测试 面世 之 初 ， 读 者 反映 其 中 最 难 做 到 的 部 分 就 是 写 规格 书 。 写 
软件 规格 书 就 好 像 像 激 口 : 大 家 部 觉得 是 件 好 事 ， 但 束 是 没 人 做 。 


为 什么 人 们 不 写 规 格 书 ? 有 人 说 跳 过 写 规格 书 的 阶段 可 以 节省 时 间 。 
这 些 人 眼中 写 规格 书 是 一 种 奢侈 ， 只 有 那些 为 NASA 制 造 太空 飞船 的 工 
程 师 ， 或 是 大 型 知名 保险 公司 的 工作 人 员 们 才 配 悍 有 。 胡说 八道 。 首 
先 ， 不 写 规 格 书 是 软件 项 目 开 发 中 最 大 的 不 必要 风险 ， 其 轧 短 程度 就 
像 不 融 装 备 就 横 罕 砚 哈 维 沙 漠 ， 心 存 贷 壮 能 逃 过 一 劫 。 那些 不 写 规格 
书 束 一 头 扎 进 代码 中 的 程序 员 和 软件 工程 师 ， 以 为 自己 是 页 枪 高 手 ， 
不 用 瞄准 束 能 拔 枪 射击 。 他 们 在 做 梦 。 他 们 的 效率 非常 低 。 他 们 写 的 
代码 烂 、 做 出 的 软件 更 烂 ， 并 且 为 项 目 平 添 了 非常 大 的 、 完 全 不 必要 
的 风险 。 




















en 
于 一 名 ) ， 不 写 规格 书 会 导致 项 目 花费 的 时 间 更 长 、 代 码 的 质量 更 
茬 。 原因 如 下 。 


规格 书 最 重要 的 功能 就 是 对 程序 进行 设计 。 即使 只 有 你 自己 在 写 代 
码 ， 规格 书 也 只 写 给 上 自己 看 ， 在 写 规格 书 的 过 程 中 ， 通过 详细 描述 程 
序 的 工作 原理 ， 你 会 被 迫 对 程序 做 真正 的 设计 。 


让 我 们 虚构 来 自 两 家 公司 的 两 个 程序 员 。 来自 急速 香 信 软件 的 史 比 迪 
小 姐 ， 从 不 写 规 格 书 。“ 规 格 书 ? 我 们 才 不 需要 那 玩意 ! ”来 自 好 脾气 软 
件 公 司 的 罗杰斯 先生 ， 在 写 代码 之 前 总 会 完成 详细 的 规格 书 。 我 有 好 
几 位 假想 中 的 朋友 ， 这 两 位 也 在 其 中 。 


史 比 迪 和 罗杰斯 有 一 个 共同 点 : 他 们 都 负责 维护 各 和 目 产品 2.0 版 本 的 历 
史 兼 容 性 。 


























史 比 迪 决 定 提供 历史 兼容 性 的 最 好 方法 是 写 一 I 1 
版 本 文件 转换 为 2.0 版 本 。 她 立刻 开始 融 代 人 码 。 裔 ， 融 ， 沿 。 

点 。 便 盘 飞 转 ， 人 尘土 飞扬 。 两 周 后 ， 她 的 转换 器 完工 了 。 i 
的 客户 不 满意 ， 因 为 她 的 代码 强迫 公司 的 所 有 人 都 必须 立即 升级 到 新 版 
本 。 史 比 迪 最 大 的 客户 Nanner Splits Unlimited 公 司 拒绝 购买 新 的 软 

件 。 


Nanner Splits 需 要 2.0 版 本 不 用 转换 就 能 处 理 1.0 版 本 的 文件 。 史 比 迪 决 
定 写 一 个 降级 转换 器 ， 并 把 它 绑 到 “保存 ”按钮 上 。 这 下 乱 套 了 ， 因为 
虽然 看 上 去 你 可 以 使 用 2.0 版 本 的 功能 ， 但 在 保存 时 ， 由 于 只 支持 1.0 版 
本 的 格式 ， 软件 会 提示 你 半 个 小 时 前 用 过 的 功能 在 旧 文 件 格式 上 不 可 
用 。 写 降 级 转换 器 不 仅 又 花 了 两 周 时 间 ， 而 且 效 果 还 不 好 。 这 样 总 共 
花费 了 4 周 时 间 。 


再 来 看 好 脾气 软件 公司 的 罗杰斯 先生 ， 他 古怪 偏执 的 一 面 表现 在 没有 规 
格 书 就 拒绝 写 代码 。 他 花 了 20 分 钟 来 做 历史 兼容 功能 的 设计 ， 想 法 和 
史 反 过 差不多 ， 规格 书 大 致 的 意思 是 


。 打开 一 个 用 旧版 本 产品 创建 的 文件 ， 目 劲 将 其 转换 成 新 版 本 的 格 


式 。 


这 个 规格 书 拿 给 客户 一 看 ， 客户 急 了 :“ 等 一 下 ! 我 们 不 想 强 迫 每 个 人 
立刻 升级 ! ”于 是 罗杰斯 先生 又 想 了 想 ， 修 改 了 说 明 书 ， 如 下 : 


。 打开 一 个 用 旧版 本 产品 创建 的 文件 ， 会 在 内 存 中 自动 将 其 转换 成 
新 版 本 的 格式 。 保存 文件 的 时 候 ， 用 户 可 以 选择 把 文件 转换 回 旧 
版 本 。 

















XT 0M; 


罗杰斯 先生 的 上 司 是 一 个 面 辐 对象 编 程 的 狂人 ， 他 看 到 规格 书 ， 觉 得 
缺点 什么 。 他 给 出 了 一 个 不 同 的 架构 。 


。 重 构 代 码 ， 使 用 两 个 接口 : V1 和 V2。 V1 包含 所 有 版 本 一 的 功能 
V2 继承 自 V1， 增加 所 有 的 新 功能 。 V1::Save 负 责 处 理 历 史 兼 容 
性 ， V2::Save 用 新 格式 来 保存 文件 。 如 果 你 打开 V1 文件 时 想 使 用 
V2 的 功能 ， 软件 会 发 出 提醒 ， 用 户 要 么 转换 文件 ， 要么 放弃 使 用 


新 功能 。 
20 分 钟 过 去 。 


罗杰斯 先生 郁 间 了 。 重 构 将 耗 时 3 个 星期 ， 而 不 是 他 预计 的 2 个 星期 ! 
但 是 这 么 做 确实 优雅 地 解决 了 用 户 的 所 有 问题 ， 所 以 他 接受 了 方案 ， 
开始 编程 。 


罗杰斯 先生 总 共用 了 3 周 零 1 小 时 。 史 皮 迪 总 共用 了 4 周 ， 但 代码 的 质量 
不 那么 好 。 


这 个 故事 的 教训 是 ， 瞎 编 一 个 例子 你 可 以 证 明 任何 事情 。 额 ， 我 不 是 
这 个 意思 。 故事 的 教训 是 ， 当 你 用 人 类 的 语言 设计 产品 时 ， 可 以 在 几 
分 钟 的 时 间 里 权衡 几 种 方案 的 利 葡 ， 然 后 修正 、 改 进 你 的 设计 。 谁 也 
不 会 为 了 在 文字 处 理 絮 里 删除 一 段 话 而 难过 。 但 如 果 你 选择 编程 的 语 
言 里 做 产品 的 设计 ， 可 能 要 人 花 数 周 的 时 间 才 能 做 出 可 以 让 人 反馈 的 设 
计 。 更 糟 的 是 ， 程 序 员 对 于 耗 时 两 周 时 间 写 出 的 代码 是 有 感情 的 ， 不 
管 这 些 代 码 错 得 多 离谱 。 无 论 史 皮 迪 的 上 司 或 是 客户 说 什么 ， 她 都 不 
会 愿意 丢 挥 她 辛 昔 写 出 的 、 漂 腕 的 转换 占 代 码 ， 尽管 这 段 代码 在 架构 
上 完全 谈 不 上 漂亮 。 结果 是 ， 最 后 交付 的 产品 形态 介 于 最 初 错误 的 设 
计 以 及 理想 的 设计 之 间 。 人 们 会 评论 它 “ 是 我 们 能 做 的 最 好 的 设计 了 ， 
毕竟 我 们 对 注音 兰 写 了 那么 多 代码 ， 总 不 能 全 都 推倒 重 来 吧 。” 这 个 评 
价 远 比 不 上 : “这 有 是 我 们 能 做 的 最 好 的 设计 ， 没 有 之 一 。” 

















国 ,| 是 可 项 格 书 的 第 一 大 理由 。 第 二 大 理由 是 节省 沟通 的 时间 
通过 写 规 格 书 ， 你 只 需要 和 别人 沟通 一 次 ， 团 队 的 其 他 成 员 只 要 去 读 
规格 书 ， 就 能 知道 程序 的 很 多 方面 。 测试 人 员 通 过 规格 书 ， 可 以 了 解 
程序 有 哪些 符合 预期 的 功能 和 行为 ， 也 就 是 该 从 哪些 角 反 去 测试 。 营 
销 人 员 以 规格 书 为 到 本 ， 撰 写 出 充满 洲 美 之 词 的 产品 白皮书 ， 然 后 放 到 
网 站 上 去 宣传 你 们 还 未 出 世 的 杰作 。 业务 拓展 人 员 经 常 误 读 规格 书 ， 

然后 用 天 号 行 空 般 的 想象 力 把 产品 塑造 成 秃顶 或 是 皮肤 疣 (warts〉 的 
克星 ， 不 过 只 要 他 们 能 忽悠 到 投资 ， 你 就 没什么 可 抱怨 的 。 开发 者 读 
了 规格 书 ， 就 知道 该 写 哪些 代码 。 客户 读 了 规格 书 ， 束 能 确信 开发 者 
们 正在 做 的 产品 是 物 有 所 值 的 。 技术 文档 编写 者 以 规格 书 为 参考 ， 写 
出 给 客户 看 的 图 文 并 成 的 说 明 书 “就 古 那 些 经 常 遗 失 或 被 丢弃 的 小 册 




















子 ， 不 过 那 是 另 一 个 故事 了 ) 。 经 理 们 读 了 规格 书 ， 然后 就 可 以 在 管 
理会 议 上 假装 一 切 尽 在 他 们 掌控 之 中 。 等 等 。 


如 果 你 没 写 规格 书 ， 所 有 这 些 沟通 的 过 程 还 是 要 发 生 ， 因为 它们 总 会 
发 生 ， 不 过 这 种 情况 下 ， 它 们 会 一 次 又 一 次 地 发 生 。 测试 人 员 拿 到 软 
件 只 能 随便 点 把 看 看 ， 因为 他 们 不 清楚 软件 怎么 样 才 算 正 第 工作 ， 一 
且 发 现 有 奇怪 的 程序 行为 ， 他 们 就 会 一 再 地 问 程序 员 各 种 思 码 的 问 
题 。 这 不 仅 会 导致 程序 员 的 工作 效率 和 被 破 坏 殉 尽 ,而 且 程序 员 在 回答 这 
些 问题 时 倾向 于 用 代码 实现 细节 来 解释 ， 而 给 不 出 所 谓 “ 恰 当 的 答 

案 ”。 也 就 是 说 ， 测试 人 员 是 基于 程序 来 测试 程序 ， 而 不 是 基于 程序 来 
测试 设计 ， 而 后 者 可 能 ， 咽 ， 还 稍微 更 有 用 一 点 。 


如 有 果 不 写 规格 书 ， 友 生 在 可 怜 的 拉 术 文档 编写 者 喘 上 的 事 才 叫 滑 重 
(和 带 有 一 丝 严 深 的 感觉 )。 他 们 通常 比较 弱势 ， 不 敢 打扰 程序 员 大 人 
们 。 许多 公司 的 情况 是 ， 如 果 拷 术 文 档 编 写 者 养 成 了 回程 序 员 提问 的 
习惯 ， 比如 茶 个 软件 怎么 样 才 算 正名 工作 ， 程序 员 就 会 癌 经 理 告状 ， 
说 目 己 被 那些 [形容 词 已 被 和 谐 ] 的 文档 编写 者 烦 得 什么 都 干 不 成 ， 能 不 
能 别 让 他 们 靠近 我 。 经 理 们 为 了 提高 工作 效率 ， 只 能 茶 止 文档 编写 者 
再 去 浪费 程序 员 们 的 宝贵 时 间 。 至 于 这 种 情况 发 生 在 哪些 公司 ， 你 从 
他 们 的 帮助 文件 和 产品 手册 上 束 看 得 出 来 ， 里 面包 含 的 信息 比 运行 软 
件 时 你 自己 得 到 的 信息 还 少 。 当 你 看 到 屏幕 上 出 现 如 下 提示 信息 


e。 你 想 开 启 LRF-1914 支 持 功 能 吗 ? 
然后 你 点 “帮助 >， 弹出 的 帮助 主题 会 让 你 活 笑 不 得 : 


。 让 你 在 使 用 LRF-1914 支 持 功 能 (默认 ) 和 不 使 用 LRF-1914 支 持 功 
能 之 间 切 换 。 如 果 你 想 使 用 LRF-1914 支 持 功能 ， 选 择 “ 是 ”或 
按 “Y”。 如 果 你 不 想 使 用 LRF-1914 支 持 功能 ， 选择 “ 否 ? 或 
按 “N” 键 。 


额 ， 谢 谢 了 。 很 明显 文档 编写 者 在 努力 掩盖 上 自己 根本 不 知道 LRF-1974 
支持 功能 是 什么 的 事实 。 他 们 不 能 问 程序 员 ， 可 能 因为 〈a) 他 们 不 好 
意思 开口 ， 或 者 〈b) 程序 员 人 品 很 差 而 且 远 在 伦敦 ， 或 者 〈c) 管理 层 
禁止 他 们 打扰 程序 员 ， 或 是 因为 其 他 的 难以 列举 的 大 公司 通病 。 但 是 
最 根本 的 问题 在 于 ， 没有 规格 书 可 以 做 参考 。 



































写 规格 书 的 第 三 大 理由 是 没有 详细 的 说 明 ， 惑 无 法 制定 计划 表 。 如 果 
你 在 攻读 博士 学 位 而 且 做 好 了 为 之 奋斗 14 年 的 准备 ， 你 可 以 没有 计划 
表 。 或 者 如 果 你 写 的 程序 有 望 成 为 下 一 个 “毁灭 公 覆 ”一 个 划时代 的 3D 游 戏 
一 证 才 注 ， 那 我 们 可 以 理直气壮 地 说 “什么 时 候 把 程序 做 结实 做 漂亮 了 ， 
我 们 就 什么 时 候 交 付 *”， 你 也 可 以 没有 计划 表 。 但 几乎 所 有 面 癌 实际 业 
务 的 开发 工作 ， 你 必须 要 知道 要 做 茶 件 事 需 要 多 长 的 时 间 ， 因为 开发 
产品 是 要 人 花 钱 的 。 买 牛 仔裤 之 前 还 要 看 价格 呢 ， 何 况 是 自负 和 鳃 亏 的 投 
资 者 ， 他 们 在 决定 是 否 开发 茶 个 产品 时 ， 当然 需要 先知 道 开发 的 时 间 
成 本 ， 进 而 换算 成 经 济 成 本 。 关于 如 何 做 计划 ， 请 阅读 我 写 的 轻松 掌 
控 软 件 开发 进度 。 


公司 党 犯 的 一 个 重大 错误 是 ， 当 大 家 对 某 些 设计 有 争议 时 ， 人 争议 从 来 
都 得 不 到 解决 。 Windows 2000 的 开发 主管 布 莱 恩 : 拟 伦 本 有 一 名 名言: 
“如 果 10 分 钟 以 内 无 法 达成 决议 ， 那 束 一 直 了 商量 到 达成 决议 为 止 。” 


太 多 的 软件 开发 机 构 都 有 这 个 问题 ， 一旦 出 现 设 计 上 的 争议 ， 通 常 出 
于 某 种 政治 原因 ， 没 有 人 站 出 来 力挽狂澜 ， 促 成 一 个 决议 。 这 导致 程 
序 员 们 只 能 束 无 关 痛 痒 的 设计 进行 开 肥 。 随 看 时 间 的 推移 ， 所 有 困难 
的 决定 都 被 推迟 到 了 最 后 一 刻 。 这 样 的 项 目 是 最 有 可 能 失败 的 项 目 。 
如 果 你 开 了 一 家 研发 东 项 新 技术 的 初创 公司 ， 并 且 友 现 公司 经 党 性 地 
无 法 做 出 决定 ， 那 你 还 不 如 趁早 关门 ， 把 钱 还 给 投资 者 ， 因为 这 样 下 
去 公司 什么 也 做 不 成 。 


在 写 规格 说 明 书 的 过 程 中 ， 所 有 那些 令 人 不 悦 的 或 大 或 小 的 设计 决定 都 
会 统统 歇 露 出 来 ， 如 末 不 写 ， 它 们 很 容易 就 被 掩盖 过 去 了 。 即使 是 非 
常 珊 雄 的 决定 ， 也 能 从 规格 书 中 看 出 问题 的 端倪 。 比如 你 们 在 做 一 个 
会 员 制 的 网 站 ， 可 能 大 家 都 同意 如 果 会 员 筷 了 密码 ， 就 通过 邮件 告知 
他 们 。 很 好 。 但 是 这 还 不 足以 指导 开发 。 要 与 出 代码 ， 你 需要 知道 那 
封 电子 邮件 的 确切 措 词 。 大 部 分 公司 都 不 信任 程序 员 的 文字 水 平 ， 不 
让 他 们 直接 撰写 真正 要 展示 给 客户 看 的 文采 《而 这 种 不 信任 通常 是 有 道 
理 的 ) 。 所 以 消 轧 的 具体 措 词 ， 需 要 区 给 茶 个 草 销 、 公 关 或 是 文学 专业 
的 人 去 拟定 。 


“亲爱 的 客户 ， 这 是 你 忘记 的 密码 。 下 次 别 这 么 大 意 了 。” 当 你 强迫 自 
己 把 规格 书写 得 规范 、 完 整 的 时 候 〈 我 马上 就 会 讲 这 个 ) ， 你 融会 注 
意 到 很 多 细节 的 问题 ， 要 么 你 可 以 立即 解决 他 们 ， 要 么 就 在 劳 边 做 一 












































个 大 大 的 红色 记号 。 


好 ， 现 在 大 家 意见 一 致 了 吧 。 规格 书 必 不 可 少 ， 就 好 像 每 个 人 都 有 和 母 
杀 ， 每 个 人 都 爱 苹 果 派 。 我 怀疑 大 部 分 人 都 明日 这 一 点 ， 而 我 发 了 这 
么 多 牢骚 ， 只 是 贻 笑 大 方 ， 并 没有 什么 教育 意义 。 问题 是 为 什么 人 们 
不 写 规格 书 呢 ? 肯定 不 是 为 了 节省 时 间 ， 实际 上 恰恰 相反 ， 而 且 我 沉 
得 大 多 数 程序 员 都 对 此 深 有 体会 。 在 大 部 分 机 构 里 唯一 能 算 作 “规格 
书 ” 的 东西 是 那 种 生硬 的 ， 篇 幅 只 有 一 页 的 文本 文档 ， 还 是 程序 员 在 同 
300 个 人 解释 过 那些 该 死 的 功能 之 后 ， 舍 愤然 一 挥 而 束 的 。) 




















辆 了 为 是 因 为 有 太 多 的 人 不 喜欢 写作 了 。 面 对 _ 张 空白 的 屏幕 
很 多 人 都 会 发 居 。 我 个 人 克服 了 这 种 奴 恨 ， 得 蔡 于 我 在 大 学 里 选 过 一 
门 识 ， 课 程 要 求 每 周 交 一 篇 3 至 5 页 的 小 品 文 。 写作 能 力也 是 一 种 肌 
肉 。 你 写 得 越 多 ， 就 越 能 写 。 如 果 你 圾 要 写 规格 书 但 写 不 出 来 ， 可 以 
先 开始 记 日 记 ， 写 博客 ， 参 加 一 个 创作 培训 班 ， 或 者 干脆 给 认识 的 人 
写 信 ， 不 管 是 亲戚 也 好 ， 你 4 年 多 没 联系 的 大 学 室友 也 罢 。 不 要 放 过 任 
何 一 个 把 词 写 在 纸 上 的 机 会 ， 持 续 改 进 你 的 规格 书写 作 技 巧 。 如 果 你 
是 软件 开发 活动 的 管理 者 ， 要 是 你 手下 的 人 不 愿意 写 规格 书 ， 就 把 他 
们 送 去 参加 一 个 为 期 两 周 的 创作 塔 训 班 ， 最 好 是 在 深山 里 举办 的 那 
种 。 


如 果 你 没有 在 一 个 要 求 写 功能 规格 书 的 公司 工作 过 ， 你 可 能 不 知道 这 
种 文档 时 什么 样 的 。 在 这 个 系列 的 下 一 篇 文章 里 ， 我 会 示范 一 个 简短 
的 规格 书 ， 供 你 参考 ， 然后 再 看 看 一 份 好 的 规格 书 应 该 包括 什么 。 请 
继续 阅读 ! 
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2.4 奥 卡 姆 剃刀 

2.5 创造 力 的 自动 化 

2.6 ”终极 侦探 

2.7 美妙 世界 的 阴暗 面 

2.8” 回 到 现实 
第 3 章 P 和 NP 

3.1 政 友 国 

3.2 ”六 度 理 论 

3.3 ”牵线 搭桥 

3.4 团 问 题 

3.5 “ 递 棍 儿 ” 

36 刷 房 于 


3.8 P 和 NP 
3.9” 敌 友 国 之 外 
3.10 ”Icosian 游 戏 的 一 个 解 





第 4 章 ”NP 中 最 难 的 问题 
4.1 第 一 个 NP 完全 问题 


a 
超越 卡 普 的 工作 





党 证 明 PzNP 

A 骗子 导论 

7.2 电路 

7 3 证 常 犯 的 错误 









8.4 

8.5 

8.6 

8.7 
第 9 意 量子 

9.1 量子 录像 机 

9.2 量子 密码 学 


9.3 ”量子 隐形 传输 
9.4 时 村 的 术 来 





